Accueil > > > ADDITION ET SOUSTRACTION AVEC VIRGULE N CHIFFRES
ADDITION ET SOUSTRACTION AVEC VIRGULE N CHIFFRES
Information sur la source
Description
comme il existe plusieurs editeur et compilateur différents
je poste sans zip deux fonctions qui sont l'addition et la soustraction,ça s'addresse au débutants.
Source
- public static String Sous (String a,String b)
- { String res ="";
- int i,m,n,l,w,x;
- int y = 0;
- int max = 0;
- int r =0;
- int base = 10;
-
- // Supprimer les virgules
- if (a.indexOf(",")> 0 && b.indexOf(",")> 0)
- { w = a.length() - a.indexOf(",");
- x = b.length() - b.indexOf(",");
- if (w>x)
- { b = b.replace(",", "");
- a = a.replace(",", "");
- for (i = 1 ; i <= w-x;i++)
- { b = b + "0";}
- y = w;
- }
- else if (x > w)
- { b = b.replace(",", "");
- a = a.replace(",", "");
- for (i = 1 ; i <= x-w;i++)
- { a = a + "0";}
- y = x;
- }
- else if (x == w)
- { b = b.replace(",", "");
- a = a.replace(",", "");
- y = x;
- }
- }
- else if (a.indexOf(",")>0 && b.indexOf(",")==-1)
- { w = a.length() - a.indexOf(",");
- for (i = 1 ; i< w; i++)
- { b = b + "0";}
- a = a.replace(",", "");
- y = w;
- }
- else if (b.indexOf(",")>0 && a.indexOf(",")== -1)
- { x = b.length() - b.indexOf(",");
- for (i = 1 ; i <x;i++)
- { a = a + "0";}
- b = b.replace(",", "");
- y = x;
- }
-
- // Réduit chaque chaines à la même longueur
- if (a.length()> b.length())
- { max = a.length();
- l = max - b.length();
- for (i =1 ;i <=l;i++)
- { b = "0"+ b;}
- }
- else if (b.length()> a.length())
- { max = b.length();
- l = max - a.length();
- for (i=1 ; i <= l;i++)
- { a = "0" + a;}
- }
- else if (a.length() == b.length())
- { max = a.length(); }
-
- // Soustrait
- String a1,b1;
- for (i = max; i>0;i--)
- { a1= a.substring(i-1,i);
- b1= b.substring(i-1,i);
- m = Integer.valueOf(a1);
- n = Integer.valueOf(b1);
- r = m - r - n;
- if (r<0)
- { a1 = String.valueOf(r+base);
- r=1;
- }
- else
- { a1 = String.valueOf(r);
- r=0;
- }
- res = a1 + res;
- }
-
- // Met la virgule s'il y a lieu
- if (y != 0) res = res.substring(0,res.length()-(y-1)) + ","+ res.substring(res.length()-(y-1),res.length());
- // Supprime les zéros à gauche
- int k=0;
- l = res.length();
- for (i = 1; i < l;i++)
- { if (res.charAt(i-1) != '0') break;
- k ++;
- }
- res = res.substring(k,res.length());
- if (y !=0)
- {// Supprime les zéros à droite
- int j=0 ;
- for (i= res.length();i > 0 ; i--)
- { if (res.charAt(i-1)!= '0') break;
- j ++;
- }
- res = res.substring(0,res.length()-j);
- if (j==(y-1))
- {res = res + "0";}
- }
- if ( res.indexOf(",")== 0 ) res = "0" + res;
- return res;
- }
-
- public static String Add (String a,String b)
- { String res ="";
- int i,m,n,l,w,x;
- int y = 0;
- int max = 0;
- int r =0;
- int base = 10;
-
- // Supprimer les virgules
- if (a.indexOf(",")> 0 && b.indexOf(",")> 0)
- { w = a.length() - a.indexOf(",");
- x = b.length() - b.indexOf(",");
- if (w>x)
- { b = b.replace(",", "");
- a = a.replace(",", "");
- for (i = 1 ; i <= w-x;i++)
- { b = b + "0";}
- y = w;
- }
- else if (x > w)
- { b = b.replace(",", "");
- a = a.replace(",", "");
- for (i = 1 ; i <= x-w;i++)
- { a = a + "0";}
- y = x;
- }
- else if (x == w)
- { b = b.replace(",", "");
- a = a.replace(",", "");
- y = x;
- }
- }
- else if (a.indexOf(",")>0 && b.indexOf(",")==-1)
- { w = a.length() - a.indexOf(",");
- for (i = 1 ; i< w; i++)
- { b = b + "0";}
- a = a.replace(",", "");
- y = w;
- }
- else if (b.indexOf(",")>0 && a.indexOf(",")== -1)
- { x = b.length() - b.indexOf(",");
- for (i = 1 ; i <x;i++)
- { a = a + "0";}
- b = b.replace(",", "");
- y = x;
- }
-
- // Réduit chaque chaines à la même longueur
- if (a.length()> b.length())
- { max = a.length();
- l = max - b.length();
- for (i =1 ;i <=l;i++)
- { b = "0"+ b;}
- }
- else if (b.length()> a.length())
- { max = b.length();
- l = max - a.length();
- for (i=1 ; i <= l;i++)
- { a = "0" + a;}
- }
- else if (a.length() == b.length())
- { max = a.length(); }
-
- // Additionne
- String a1,b1;
- for (i = max; i>0;i--)
- { a1= a.substring(i-1,i);
- b1= b.substring(i-1,i);
- m = Integer.valueOf(a1);
- n = Integer.valueOf(b1);
- r = m + r + n;
- if (r>= base)
- { a1 = String.valueOf(r-base);
- r=1;
- }
- else
- { a1 = String.valueOf(r);
- r=0;
- }
- res = a1 + res;
-
- if ((r==1) && (i==1)) res = "1"+ res;
- }
-
- // Met la virgule s'il y a lieu
- if (y != 0)
- { res = res.substring(0,res.length()-(y-1)) + ","+ res.substring(res.length()-(y-1),res.length());
- // Supprime les zéros à droite
- int j=0 ;
- for (i= res.length();i > 0 ; i--)
- { if (res.charAt(i-1)!= '0') break;
- j ++;
- }
- res = res.substring(0,res.length()-j);
- if (j==(y-1))
- {res = res + "0";}
- }
- return res;
- }
public static String Sous (String a,String b)
{ String res ="";
int i,m,n,l,w,x;
int y = 0;
int max = 0;
int r =0;
int base = 10;
// Supprimer les virgules
if (a.indexOf(",")> 0 && b.indexOf(",")> 0)
{ w = a.length() - a.indexOf(",");
x = b.length() - b.indexOf(",");
if (w>x)
{ b = b.replace(",", "");
a = a.replace(",", "");
for (i = 1 ; i <= w-x;i++)
{ b = b + "0";}
y = w;
}
else if (x > w)
{ b = b.replace(",", "");
a = a.replace(",", "");
for (i = 1 ; i <= x-w;i++)
{ a = a + "0";}
y = x;
}
else if (x == w)
{ b = b.replace(",", "");
a = a.replace(",", "");
y = x;
}
}
else if (a.indexOf(",")>0 && b.indexOf(",")==-1)
{ w = a.length() - a.indexOf(",");
for (i = 1 ; i< w; i++)
{ b = b + "0";}
a = a.replace(",", "");
y = w;
}
else if (b.indexOf(",")>0 && a.indexOf(",")== -1)
{ x = b.length() - b.indexOf(",");
for (i = 1 ; i <x;i++)
{ a = a + "0";}
b = b.replace(",", "");
y = x;
}
// Réduit chaque chaines à la même longueur
if (a.length()> b.length())
{ max = a.length();
l = max - b.length();
for (i =1 ;i <=l;i++)
{ b = "0"+ b;}
}
else if (b.length()> a.length())
{ max = b.length();
l = max - a.length();
for (i=1 ; i <= l;i++)
{ a = "0" + a;}
}
else if (a.length() == b.length())
{ max = a.length(); }
// Soustrait
String a1,b1;
for (i = max; i>0;i--)
{ a1= a.substring(i-1,i);
b1= b.substring(i-1,i);
m = Integer.valueOf(a1);
n = Integer.valueOf(b1);
r = m - r - n;
if (r<0)
{ a1 = String.valueOf(r+base);
r=1;
}
else
{ a1 = String.valueOf(r);
r=0;
}
res = a1 + res;
}
// Met la virgule s'il y a lieu
if (y != 0) res = res.substring(0,res.length()-(y-1)) + ","+ res.substring(res.length()-(y-1),res.length());
// Supprime les zéros à gauche
int k=0;
l = res.length();
for (i = 1; i < l;i++)
{ if (res.charAt(i-1) != '0') break;
k ++;
}
res = res.substring(k,res.length());
if (y !=0)
{// Supprime les zéros à droite
int j=0 ;
for (i= res.length();i > 0 ; i--)
{ if (res.charAt(i-1)!= '0') break;
j ++;
}
res = res.substring(0,res.length()-j);
if (j==(y-1))
{res = res + "0";}
}
if ( res.indexOf(",")== 0 ) res = "0" + res;
return res;
}
public static String Add (String a,String b)
{ String res ="";
int i,m,n,l,w,x;
int y = 0;
int max = 0;
int r =0;
int base = 10;
// Supprimer les virgules
if (a.indexOf(",")> 0 && b.indexOf(",")> 0)
{ w = a.length() - a.indexOf(",");
x = b.length() - b.indexOf(",");
if (w>x)
{ b = b.replace(",", "");
a = a.replace(",", "");
for (i = 1 ; i <= w-x;i++)
{ b = b + "0";}
y = w;
}
else if (x > w)
{ b = b.replace(",", "");
a = a.replace(",", "");
for (i = 1 ; i <= x-w;i++)
{ a = a + "0";}
y = x;
}
else if (x == w)
{ b = b.replace(",", "");
a = a.replace(",", "");
y = x;
}
}
else if (a.indexOf(",")>0 && b.indexOf(",")==-1)
{ w = a.length() - a.indexOf(",");
for (i = 1 ; i< w; i++)
{ b = b + "0";}
a = a.replace(",", "");
y = w;
}
else if (b.indexOf(",")>0 && a.indexOf(",")== -1)
{ x = b.length() - b.indexOf(",");
for (i = 1 ; i <x;i++)
{ a = a + "0";}
b = b.replace(",", "");
y = x;
}
// Réduit chaque chaines à la même longueur
if (a.length()> b.length())
{ max = a.length();
l = max - b.length();
for (i =1 ;i <=l;i++)
{ b = "0"+ b;}
}
else if (b.length()> a.length())
{ max = b.length();
l = max - a.length();
for (i=1 ; i <= l;i++)
{ a = "0" + a;}
}
else if (a.length() == b.length())
{ max = a.length(); }
// Additionne
String a1,b1;
for (i = max; i>0;i--)
{ a1= a.substring(i-1,i);
b1= b.substring(i-1,i);
m = Integer.valueOf(a1);
n = Integer.valueOf(b1);
r = m + r + n;
if (r>= base)
{ a1 = String.valueOf(r-base);
r=1;
}
else
{ a1 = String.valueOf(r);
r=0;
}
res = a1 + res;
if ((r==1) && (i==1)) res = "1"+ res;
}
// Met la virgule s'il y a lieu
if (y != 0)
{ res = res.substring(0,res.length()-(y-1)) + ","+ res.substring(res.length()-(y-1),res.length());
// Supprime les zéros à droite
int j=0 ;
for (i= res.length();i > 0 ; i--)
{ if (res.charAt(i-1)!= '0') break;
j ++;
}
res = res.substring(0,res.length()-j);
if (j==(y-1))
{res = res + "0";}
}
return res;
}
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
calcul [ par celfun ]
je cherche comment faire pour programmer un calcul exemple0 1 1 2 3 5 8 13 21 34 55l'addition se fait a partir des 2 derniers chiffres
calcul de besoin d'un logiciel GPAO [ par lebobby ]
Salut les jeunes... Je suis à la recherche, d'un petit applicatif JAVA qui permet de calculer besoins bruts et ordre prévisionnels de produits dans le
calcul de besoin d'un logiciel GPAO [ par lebobby ]
Salut les jeunes... Je suis à la recherche, d'un petit applicatif JAVA qui permet de calculer besoins bruts et ordre prévisionnels de produits dans le
Classe Matrice [ par progueur ]
Bonjour,Pour répondre à corebreaker, j'aurais besoin d'une classe Matrice dont les éléments sont reels.Il me faudrait le calcul du determinant, de la
calcul de checksum (ASCII <==> hexa) [ par knd ]
Bonjour,je voudrais savoir comment calculer la valeur hexa d une trame ascii?==> chaque caractere a une valeur ascii! comment trouver cette valeur
calcul aléatoire gaussian [ par la_taupe12 ]
bonjour, je n'arrive pas a trouver une fonction que permet de me retourner un valeur aléatoire Gaussienne de moyenne nulle et de variance paramétrable
calcul d'une moyenne en JVS [ par ludoweb ]
Bonjour à tousComment faire pour calculer la moyenne de n champ de texte ?voici le code qui génére les champs de texte (il n'est pas de moi, merci a m
Calcul de position d'un pixel suivant quelques critères... [ par gaelcal ]
Bonjour !Voilà j'ai un problème qui me prend la tête depuis une semaine et là je craque un peu !Je vous explique:A la base j'ai la position de 2 point
Pb calcul avec un string [ par nicboi ]
Salutje cherche a faire un calcul a partir d'un string du style "10+12*52/36-4" sans tenir compte des priorite d'operation.Existe t'il une fonction ja
programme d'un calcul scientifique avec java [ par ayour1981 ]
bonjour,j'ai un programme qui calcul en 15 points un nombre de paramétre à savoir la température de l'eau .....mais le probleme c'est que lorsque j'in
|
Derniers Blogs
NDEPEND V3. J'ADORE SON INTéGRATION AVEC VS2010NDEPEND V3. J'ADORE SON INTéGRATION AVEC VS2010 par tja
Après une petite introduction à son utilisation que vous pouvez lire ici j'ai également eu envie d'installer ma copie et de jouer un peu avec. Après les premières minutes de son utilisation. J'ai tout de suite ADORE. L'utilisation intuitive sans besoi...
Cliquez pour lire la suite de l'article par tja XNA 4.0 POUR CRéER DES JEUX 3D SOUS WINDOWS PHONE 7 SERIESXNA 4.0 POUR CRéER DES JEUX 3D SOUS WINDOWS PHONE 7 SERIES par RaptorXP
On savait déjà que le développement d'applications pour Windows Phone 7 Series se ferait par l'intermediaire de Silverlight et XNA. Les détails, et outils de développement (selon cetaines rumeurs) sont attendus pour le MIX10 la semaine prochaine à Las...
Cliquez pour lire la suite de l'article par RaptorXP [TOOLS] NDEPEND 3 DANS VISUAL STUDIO, WAAAAAAAOU!!![TOOLS] NDEPEND 3 DANS VISUAL STUDIO, WAAAAAAAOU!!! par JeremyJeanson
NDepend passé en version 3. Comme pour toute version majeur, la version 3 a son lots de nouveautés : performances, fonctionnalités accrues . etc . Mais dans tout cela il y a la fonctionnalité qui dénote. Le petit truc qui fait que NDepend me fait dire Waa...
Cliquez pour lire la suite de l'article par JeremyJeanson [WF4] GROSSES MéPRISES EN PERSPECTIVE SUR LE KIT DE MIGRATION WF3->WF4[WF4] GROSSES MéPRISES EN PERSPECTIVE SUR LE KIT DE MIGRATION WF3->WF4 par JeremyJeanson
Comme un certain nombre de fanatiques des flux RSS, je suis avec grand intérêt les articles de la team WCF/WF et forcément l'annonce d'hier concernant un kit de migration WF3->WF4 m'a fait chaud au c½ur ;) (pour rappel, mon post au sujet de la migratio...
Cliquez pour lire la suite de l'article par JeremyJeanson RéUNION DU CLUB MOSS PARISRéUNION DU CLUB MOSS PARIS par VANNESTE Xavier
Bonjour à tous la réunion du club moss aura lieu le 15 mars 2010 à 14 heures:
14:00 - 14:05 Paris, EROL GIRAUDY + Gaetan BOUVERET + Nicolas Georgeault intro Présentateur : Pierre Erol GIRAUDY14:05 - 14:30 Paris, Worflow - visio Services - We...
Cliquez pour lire la suite de l'article par VANNESTE Xavier
Forum
MODéLISATIONMODéLISATION par lallou22
Cliquez pour lire la suite par lallou22 RE : API COMMUNESRE : API COMMUNES par katamara
Cliquez pour lire la suite par katamara
Logiciels
Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods Konvertor (4.00)KONVERTOR (4.00)Le logiciel est un gestionnaire multimedia affichant, jouant et convertissant plus de 2000 format... Cliquez pour télécharger Konvertor Xlite (v 3.0 build 41150)XLITE (V 3.0 BUILD 41150)c'est un logiciel qui permet de téléphoner par Internet à l'aide d'un compte SIP pratique pour le... Cliquez pour télécharger Xlite Academy System (10.9.3.0)ACADEMY SYSTEM (10.9.3.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System
|