Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

VERSION JAVA DE : ROMANUTILS, TOUT POUR CONVERTIR LES CHIFFRES ROMAINS VERS LES ENTIERS ET INVERSEMENT


Information sur la source

Catégorie :Maths et Algorithmes Classé sous : conversion, chiffres, nombres, romain, entier Niveau : Débutant Date de création : 30/10/2007 Date de mise à jour : 30/10/2007 16:57:09 Vu / téléchargé: 5 946 / 128

Note :
10 / 10 - par 1 personne
10,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

Commentaire sur cette source (1)
Ajouter un commentaire et/ou une note

Description

Rapide portage de l'excellente source Delphi disponible à
http://www.delphifr.com/code.aspx?ID=34428
 

Source

  • public class RomanUtils
  • {
  • private final static String[] acceptedchar={"I","V","X","L","C","D","M"};
  • private final static String[] _RRUTR = {"","I","II","III","IV","V","VI","VII","VIII","IX"};
  • private final static String[] _RRDTR = {"","X","XX","XXX","XL","L","LX","LXX","LXXX","XC"};
  • private final static String[] _RRCTR = {"","C","CC","CCC","CD","D","DC","DCC","DCCC","CM"};
  • private final static String[] _RRMTR = {"","M","MM","MMM","","","","","",""};
  • /**
  • * Validate if the string entered is a right Roman number
  • * @param val
  • * @return true if ok
  • */
  • static boolean IsRomanNumber(String val)
  • {
  • boolean actuval;
  • for (int i=0;i<val.length();i++)
  • {
  • actuval=false;
  • for (int j=0;j<acceptedchar.length;j++)
  • if (val.substring(i, i+1).equals(acceptedchar[j])) actuval=true;
  • if (actuval==false) return false;
  • }
  • return true;
  • }
  • /**
  • * Validate if the entered integer value is in the accepted limits
  • * @param val
  • * @return true if ok
  • */
  • static boolean IsRomanNumber(int val)
  • {
  • if ((val>0)&&(val<=39999)) return true;
  • return false;
  • }
  • /**
  • * return the value of a Roman figure
  • * @param vv = The figure
  • * @return The corresponding value
  • */
  • static int RomanCharToValue(char vv)
  • {
  • switch (vv)
  • {
  • case 'I': return 1;
  • case 'V': return 5;
  • case 'X': return 10;
  • case 'L': return 50;
  • case 'C': return 100;
  • case 'D': return 500;
  • case 'M': return 1000;
  • }
  • return 0;
  • }
  • /**
  • * Return the Roman number string corresponding to the value entered.
  • * @param value to convert
  • * @return String value
  • */
  • public static String IntToRoman(int i)
  • {
  • if (IsRomanNumber(i))
  • {
  • if (i>=0 && i<=9) return _RRUTR[i];
  • if (i>=10 && i<=99) return _RRDTR[i / 10]+ _RRUTR[i % 10];
  • if (i>=100 && i<=999) return _RRCTR[i / 100]+ _RRDTR[(i / 10) % 10]+ _RRUTR[i % 10];
  • if (i>=1000 && i<=3999) return _RRMTR[i / 1000]+_RRCTR[(i / 100) % 10]+_RRDTR[(i / 10) % 10]+_RRUTR[i % 10];
  • }//endif
  • return "";
  • }
  • /**
  • * Return the int value correspondif of a Roman String entered
  • * @param value in roman figures
  • * @return int value
  • */
  • public static int RomanToInt(String RN)
  • {
  • int oc,NewRV,OldRV=0,Result=0;
  • if (IsRomanNumber(RN))
  • {
  • for (oc=0;oc<RN.length();oc++)
  • {
  • NewRV = RomanCharToValue(RN.toCharArray()[oc]);
  • if (NewRV > OldRV)
  • {
  • Result+=NewRV-(OldRV<<1);
  • }else
  • {
  • Result+=NewRV;
  • }//endif
  • OldRV=NewRV;
  • }//endfor
  • }else
  • return -1;//endif
  • return Result;
  • }
  • }
public class RomanUtils 
{
	private final static String[] acceptedchar={"I","V","X","L","C","D","M"};
	
	private final static String[] _RRUTR = {"","I","II","III","IV","V","VI","VII","VIII","IX"};
	private final static String[] _RRDTR = {"","X","XX","XXX","XL","L","LX","LXX","LXXX","XC"};
	private final static String[] _RRCTR = {"","C","CC","CCC","CD","D","DC","DCC","DCCC","CM"};
	private final static String[] _RRMTR = {"","M","MM","MMM","","","","","",""};

	
	/**
	 * Validate if the string entered is a right Roman number
	 * @param val
	 * @return true if ok
	 */
	static boolean IsRomanNumber(String val)
	{
		boolean actuval;
		
		for (int i=0;i<val.length();i++)
		{
			actuval=false;
			for (int j=0;j<acceptedchar.length;j++)
				if (val.substring(i, i+1).equals(acceptedchar[j])) actuval=true;
			if (actuval==false) return false;
		}
		return true;
	}
	
	/**
	 * Validate if the entered integer value is in the accepted limits
	 * @param val
	 * @return true if ok
	 */
	static boolean IsRomanNumber(int val)
	{
		if ((val>0)&&(val<=39999)) return true;
		return false;
	}
	
	/**
	 * return the value of a Roman figure
	 * @param vv = The figure
	 * @return The corresponding value
	 */
	static int RomanCharToValue(char vv)
	{
		switch (vv)
		{
			case 'I': return 1;
			case 'V': return 5;
			case 'X': return 10;
			case 'L': return 50;
			case 'C': return 100;
			case 'D': return 500;
			case 'M': return 1000;
		}
		return 0;
	}
	
	/**
	 * Return the Roman number string corresponding to the value entered.  
	 * @param value to convert
	 * @return String value
	 */
	public static String IntToRoman(int i)
	{
		if (IsRomanNumber(i))
		{
			
			if (i>=0 && i<=9) return _RRUTR[i];
			if (i>=10 && i<=99) return _RRDTR[i / 10]+ _RRUTR[i % 10];
			if (i>=100 && i<=999) return _RRCTR[i / 100]+ _RRDTR[(i / 10) % 10]+ _RRUTR[i % 10];
			if (i>=1000 && i<=3999) return _RRMTR[i / 1000]+_RRCTR[(i / 100) % 10]+_RRDTR[(i / 10) % 10]+_RRUTR[i % 10];

		}//endif
		
		return "";
	}
	
	/**
	 * Return the int value correspondif of a Roman String entered
	 * @param value in roman figures
	 * @return int value
	 */
	public static int RomanToInt(String RN)
	{
		int oc,NewRV,OldRV=0,Result=0;
		
		if (IsRomanNumber(RN))
		{
			for (oc=0;oc<RN.length();oc++)
			{
				NewRV = RomanCharToValue(RN.toCharArray()[oc]);
				if (NewRV > OldRV)
				{
					Result+=NewRV-(OldRV<<1);
				}else
				{
					Result+=NewRV;
				}//endif
				OldRV=NewRV;
			}//endfor
			
		}else
			return -1;//endif

		return Result;
	}
}

Conclusion

Je ne me suis pas amusé à faire des tests de performance...
De toutes façons, je doute qu'un jour ce soit utilisé dans des flux tendus.
Et si c'est le cas, le boulot est prémâché...

 

Fichier Zip

Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !
  •   RomanNumbers
    •   be
      •   dje
    • .classpathTélécharger ce fichier [Réservé aux membres club]226 octets
    • .projectTélécharger ce fichier [Réservé aux membres club]388 octets

Télécharger le zip

Historique

30 octobre 2007 16:57:09 :
Problèmes lors de l'enregistrement de la source... Donc, l'URL n'était pas direk!

Commentaires et avis

signaler à un administrateur
Commentaire de f0xi le 19/01/2008 10:43:57 administrateur CS 10/10

Oh! translation 1:1 de ma source en Java (a 98% je peux pas verifier l'exactitude du code java)!
Mais bon boulot, traduire d'un langage a l'autre demande pas mal de competence l'exercice semble reussi ici, felicitation!

Ajouter un commentaire

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 Chiffres Lettres [ par DarkKing ] slt,j'ai un petit probleme je veux ecrie un programme pour convertir un nombre entier en un chaine de caractère.10 dix134 cent trente quatre 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 JtexteField contient que de chiffres [ par aliahmad ] salutcomment je fais pour q'un JtexteField accepte de clavier que 2 chiffre, en fait je vais saisir dans ce texteField seulement le jour de certaine d Problème de d'affichage d'un double dans une zone de texte [ par beberto56 ] Bonjour,j'ai une frame avec trois zones de texte ou je multiplie des double avec une précision de deux chiffres après la virgule dans les deux premièr 2003-02-01 to 01/02/2003 conversion ou quoi ?? [ par amine1234Z ] Salutlorsque je click sur un bouton, la zone de texte txt_Valeur reçoit comme valeur: 2003-02-01 moi je veux la rendre comme : 01/02/2003est ce que je Remplacement d'un mot par le renvoi d'une fonction dans un string [ par tenev911 ] Bonjour, J'ai un problème plutot génant, j'ai posté ce sujet sur developpez.com sans grand résultat, j'aurai surement plus de chance ici :) J'ai act


Nos sponsors

Sondage...

CalendriCode

Juillet 2009
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
2728293031  

Consulter la suite du CalendriCode

Téléchargements

Comparez les prix Nouvelle version

Photothèque Nouveau !



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,577 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.