Accueil > > > ROMANOP : UN UTILITAIRE POUR LES NOMBRES ROMAINS (CONVERSION ROMAN -> ENTIERS, ENTIERS -> ROMAINS, CALCULS...)
ROMANOP : UN UTILITAIRE POUR LES NOMBRES ROMAINS (CONVERSION ROMAN -> ENTIERS, ENTIERS -> ROMAINS, CALCULS...)
Information sur la source
Description
Voici une utilitaire sur les nombres romains. Il permet la conversion de nombres romains vers les entiers et inversement. Il dispose aussi d'un méthode calc() qui prend deux chaines de caractères représentant deux nombres romains et un char correspondant à l'opérateur. Il retourne le résultat sous la forme d'une chaine de caractère représentant le résultat du calcul sous forme romaine. Cette classe est facilement utilisable pour tout code manipulant les nombres romains. Un class Main est incluse pour vous aider à comprendre son fonctionnement.
Source
- package romanop;
-
- import java.util.*;
-
- /**
- * @author Delache Michaël
- */
- public class RomanOp {
- private static final List<String> keys = new ArrayList<String>();
- private static final List<Integer> values = new ArrayList<Integer>();
-
- /**
- * Constructor of the RomanCalc class, initializes the two tables
- */
- public RomanOp() {
- keys.add("M");
- values.add(1000);
- keys.add("CM");
- values.add(900);
- keys.add("D");
- values.add(500);
- keys.add("CD");
- values.add(400);
- keys.add("C");
- values.add(100);
- keys.add("XC");
- values.add(90);
- keys.add("L");
- values.add(50);
- keys.add("XL");
- values.add(40);
- keys.add("X");
- values.add(10);
- keys.add("IX");
- values.add(9);
- keys.add("V");
- values.add(5);
- keys.add("IV");
- values.add(4);
- keys.add("I");
- values.add(1);
- }
- /**
- * Convert Roman to int
- * @param s Roman number
- * @return An int representing the roman number
- */
-
- public int toInt(final String s) {
- int res = 0;
- int size = s.length();
- String tmp = "";
- if (size == 1) {
- res = this.getInt(s);
- }
- if (size == 2) {
- if (keys.contains(s)) {
- res = this.getInt(s);
- }
- else {
- res += this.toInt(s.substring(0,1));
- res += this.toInt(s.substring(1,2));
- }
- }
- if (size > 2) {
- if (keys.contains(tmp = s.substring(size-2, size))) {
- res += this.getInt(tmp);
- res += this.toInt(s.substring(0, size-2));
- }
- else {
- tmp = s.substring(size-1, size);
- res += this.getInt(tmp);
- res += this.toInt(s.substring(0, size-1));
- }
- }
- return res;
- }
-
- /**
- * Returns the integer value of the roman value given by <i>s</i> or 0 if <i>s</i> is not in the table
- */
- public int getInt(final String s) {
- int res = 0;
- for (String str : keys) {
- if (str.equals(s)) {
- int index = keys.indexOf(str);
- res = values.get(index);
- }
- }
- return res;
- }
-
- /**
- * Converts integer value into roman value
- * @param i the integer to convert
- * @return a string representing the roman value
- */
- public String toRoman(final int i) {
- int cpt = i;
- String res = "";
- while (cpt > 0) {
- for (int j : values) {
- if ((cpt/j) >= 1) {
- int index = values.indexOf(j);
- res += keys.get(index);
- cpt -= j;
- break;
- }
- }
- }
- return res;
- }
-
- /**
- * Calculates the result of the operation determined by the two operands and the operator
- * @param x operand 1
- * @param y operand 2
- * @param op operator
- * @return the result
- */
- public String calc (final String x, final String y, final char op) {
- if (this.isOk(x) && this.isOk(y)) {
- int x1 = this.toInt(x);
- int y1 = this.toInt(y);
- switch (op) {
- case '+' :
- return this.toRoman(x1 + y1);
- case '-' :
- return this.toRoman(x1 - y1);
- case '*' :
- return this.toRoman(x1 * y1);
- case '/' :
- return this.toRoman(x1 / y1);
- default :
- break;
- }
- }
- return null;
- }
-
- /**
- * Says if the roman value given by <i>s</i> respect the roman value syntax
- * @param s the roman value to verify
- * @return true if <i>s</i> is correctly formed according to the roman value syntax (ie IV for 4 and not IIII), false else
- */
- public Boolean isOk(final String s) {
- int i = this.toInt(s);
- String str = this.toRoman(i);
- return s.equals(str);
- }
-
- }
package romanop;
import java.util.*;
/**
* @author Delache Michaël
*/
public class RomanOp {
private static final List<String> keys = new ArrayList<String>();
private static final List<Integer> values = new ArrayList<Integer>();
/**
* Constructor of the RomanCalc class, initializes the two tables
*/
public RomanOp() {
keys.add("M");
values.add(1000);
keys.add("CM");
values.add(900);
keys.add("D");
values.add(500);
keys.add("CD");
values.add(400);
keys.add("C");
values.add(100);
keys.add("XC");
values.add(90);
keys.add("L");
values.add(50);
keys.add("XL");
values.add(40);
keys.add("X");
values.add(10);
keys.add("IX");
values.add(9);
keys.add("V");
values.add(5);
keys.add("IV");
values.add(4);
keys.add("I");
values.add(1);
}
/**
* Convert Roman to int
* @param s Roman number
* @return An int representing the roman number
*/
public int toInt(final String s) {
int res = 0;
int size = s.length();
String tmp = "";
if (size == 1) {
res = this.getInt(s);
}
if (size == 2) {
if (keys.contains(s)) {
res = this.getInt(s);
}
else {
res += this.toInt(s.substring(0,1));
res += this.toInt(s.substring(1,2));
}
}
if (size > 2) {
if (keys.contains(tmp = s.substring(size-2, size))) {
res += this.getInt(tmp);
res += this.toInt(s.substring(0, size-2));
}
else {
tmp = s.substring(size-1, size);
res += this.getInt(tmp);
res += this.toInt(s.substring(0, size-1));
}
}
return res;
}
/**
* Returns the integer value of the roman value given by <i>s</i> or 0 if <i>s</i> is not in the table
*/
public int getInt(final String s) {
int res = 0;
for (String str : keys) {
if (str.equals(s)) {
int index = keys.indexOf(str);
res = values.get(index);
}
}
return res;
}
/**
* Converts integer value into roman value
* @param i the integer to convert
* @return a string representing the roman value
*/
public String toRoman(final int i) {
int cpt = i;
String res = "";
while (cpt > 0) {
for (int j : values) {
if ((cpt/j) >= 1) {
int index = values.indexOf(j);
res += keys.get(index);
cpt -= j;
break;
}
}
}
return res;
}
/**
* Calculates the result of the operation determined by the two operands and the operator
* @param x operand 1
* @param y operand 2
* @param op operator
* @return the result
*/
public String calc (final String x, final String y, final char op) {
if (this.isOk(x) && this.isOk(y)) {
int x1 = this.toInt(x);
int y1 = this.toInt(y);
switch (op) {
case '+' :
return this.toRoman(x1 + y1);
case '-' :
return this.toRoman(x1 - y1);
case '*' :
return this.toRoman(x1 * y1);
case '/' :
return this.toRoman(x1 / y1);
default :
break;
}
}
return null;
}
/**
* Says if the roman value given by <i>s</i> respect the roman value syntax
* @param s the roman value to verify
* @return true if <i>s</i> is correctly formed according to the roman value syntax (ie IV for 4 and not IIII), false else
*/
public Boolean isOk(final String s) {
int i = this.toInt(s);
String str = this.toRoman(i);
return s.equals(str);
}
}
Conclusion
Bien évidemment, vous êtes entièrement libre (et même encouragés) de modifier/copier/distribuer ce source.
Si vous voyez des améliorations et/ou bugs dans ce code, je vous invite à me prévenir par email.
Vous pourrez récupérer, ci-joint, un fichier zip contenant les dossier src (source) et doc (Documentation Java) ainsi qu'un fichier jar exécutable.
Historique
- 03 juin 2008 15:19:38 :
- Modification des modificateurs pour les attributs keys et values afin de les rendre static
- 03 juin 2008 16:39:01 :
- Modification du code de la méthode calc.
Tests "if" remplacés par un switch
- 04 juin 2008 11:38:32 :
- Modifications mineures dont quelques appels non statiques changés en appels statiques vers les attributs keys et values de la classe RomanOp
- 04 juin 2008 11:39:02 :
- Modifications mineures dont quelques appels non statiques changés en appels statiques vers les attributs keys et values de la classe RomanOp
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Conversion String / Int [ par Skeetle ]
J'ai un petit soucis, je cherche desespérément à convertir une String en entier...Je m'expliqueDans le code " String toto = "2"; ", je veux pouvoir
conversion d'une chaine de caractére en entier [ par moooonaaaa ]
Salem,j'ai une chaine de caractére de la forme suivante"a.b.c.d"je veux faire un test sur ces valeurs.Il faut que tous soit des entiers.j'utilise Toke
Aide conversion entier => binaire [ par djiaydjo ]
Salut la rooums;Voila je suis entrain de faire un petit programme et dans ce dernier j'aurai besoin de convertir un entier en binaire.J'ai vu qu'il y
CodeBarre et conversion binaire ? ca marche comment ? [ par djiaydjo ]
Salut,Etant moi meme entrain de faire un générateur de code barre, j'aurai besoin d'un éclairecissement : j'ai vu qu'il y a quelqu'un qui a déjà posté
conversion format video [ par oisurge ]
Bonjour,J'ai une appli java qui génère du .mov avec JMF, mais le fichier est trop gros et je voudrais le convertir en mpeg (JMF n'est pas capable d'en
Covertir une Donnée d'un fichier en entier [ par majormadidi1984 ]
Bonjour tout le monde, En effet j'essaie de convertir un string que j'ai récupéré dans un fichier texte pour le convertir un entier, mais je n'y parv
Générer des nombres unique [ par moonracker0210 ]
Bonjour à tous. Je cherche à générer une liste de nombre allant de 1 à 54. Jusque la, pas de soucis. Mais j'aimerais que cette liste contiennent des
transforme un entier en lettre sous iReport [ par hafedhaouni ]
salut; Comment faire pour [b]transforme un entier en lettre[/b] avec iReport merci.
Conversion d'une chaine en une matrice d'entiers [ par bimen ]
Salut tout le monde, Je suis en train de faire une application de plus court chemin (chemin moins coûteux). Mon input est une grille de coût stockée
calculer diviseurs entiers - urgent [ par Herine ]
Bonjour, Je viens de découvrir ce forum qui a l'air pas mal du tout. Je dois écrire un programme java qui compte le nombre de diviseurs entiers d'
|
Derniers Blogs
UNE JOLIE-HORLOGE ET PAS QU'UN PEU !UNE JOLIE-HORLOGE ET PAS QU'UN PEU ! par neodante
Pour les possesseurs d'iPhone, ça y est Bijin Tokei - qui se traduit littéralement en Français par " Jolie Horloge " - est arrivé et GRATUITEMENT s'il vous plaît ! Après la version Tokyo, Hokkaido, night club, racing, Gal, "pour les mademoiselles'", . voi...
Cliquez pour lire la suite de l'article par neodante TECHDAYS PARIS 2010 : CONNECTEZ VOS DONNéES à SHAREPOINT 2010 AVEC LES BUSINESS CONNECTIVITY SERVICESTECHDAYS PARIS 2010 : CONNECTEZ VOS DONNéES à SHAREPOINT 2010 AVEC LES BUSINESS CONNECTIVITY SERVICES par ROMELARD Fabrice
Animé par: Gaetan Bouveret et Julien Chomarat Business Connectivity Services (BCS) est dans SharePoint 2010 la version 2 de Business Data Catalog (BDC dans SharePoint 2007). Il s'agit de la solution permettant de visualiser des données provenan...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice [DIVERS] SUIVRE VOS SéRIES PRéFéRéS SUR LA TOILE[DIVERS] SUIVRE VOS SéRIES PRéFéRéS SUR LA TOILE par orion
Comme de nombreux geek, je suis un grand amateur de série TV et je rate régulièrement des épisodes de mes séries préférés. Une solution s'offre à vous avec ce merveilleux site : Tv Gorge - www.tvgorge.com Moteur de recherche à l'appui, vous pouvez ...
Cliquez pour lire la suite de l'article par orion TECHDAYS PARIS 2010 : LA BI DANS SHAREPOINT 2010TECHDAYS PARIS 2010 : LA BI DANS SHAREPOINT 2010 par ROMELARD Fabrice
Animé par: Vincent Bellet et Baptiste Giraudier La BI dans SharePoint 2010, Les nouveaux services d'application dans SP2010 et SQL Server Reporting services 2008 R2. La BI dans SharePoint est généralisée pour tous afin de permettre à tous les coll...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
DB-MAIN (9.1.0)DB-MAIN (9.1.0)DB-MAIN is a data-modeling and data-architecture tool. It is designed to help developers and anal... Cliquez pour télécharger DB-MAIN Xilisoft DPG Convertisseur (5.1.37.0120)XILISOFT DPG CONVERTISSEUR (5.1.37.0120)Xilisoft DPG Convertisseur offre aux fans de Nintendo DS une bonne solution leur permettant de dé... Cliquez pour télécharger Xilisoft DPG Convertisseur GraphicsGale (2.01.01)GRAPHICSGALE (2.01.01)GraphicsGale est un logiciel de PixelArt avec de nombreuse fonctionnalités permettant de réalisé ... Cliquez pour télécharger GraphicsGale Architecte 3D (Platinum 2010)ARCHITECTE 3D (PLATINUM 2010)Architecte 3D Platinium vous permet de concevoir facilement les plans votre future maison, de l'é... Cliquez pour télécharger Architecte 3D TeamViewer 5 (TeamViewer 5)TEAMVIEWER 5 (TEAMVIEWER 5)Dépanner un ami,expliquer une manipulation devient un jeu d'enfant.
Prise en main d'un autre ord... Cliquez pour télécharger TeamViewer 5
|