begin process at 2012 02 15 11:13:11
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Maths et Algorithmes

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

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


 Information sur la source

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

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
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é :9 801 / 177

Auteur : dje_jay

Ecrire un message privé
Commentaire sur cette source (2)
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

Les Membres Club peuvent 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!

 Sources du même auteur

Source avec Zip Source avec une capture LECTEUR DE CERTIFICATS GPG
Source avec Zip Source avec une capture COMMANDE "CAL" SOUS *UX

 Sources de la même categorie

IMPLÉMENTATION DE L'ENSEMBLE C AVEC JAVA par Scupper
CALCUL D'EXPONENTIEL ( PRÉCISION MODIFIABLE) par Scupper
Source avec Zip TRANSFORMATION D'UNE EXPRESSION ARITHMETIQUE (INFIXÉ) EN POS... par billatosco
PROBLÈME DES N-REINES par jojolemariole
Source avec Zip ARRAYMATRIX -MATRICE MULTIDIMENSIONELLE ET GÉNÉRIQUE- , IMP... par labandus

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture CODE SOURCE EDITEUR BINAIRE par smaili
Source avec Zip CONVERSION D'UN FICHIER IMAGE CD AUDIO CIF CRÉÉ PAR EASY CD ... par fridolindachs
Source avec Zip Source avec une capture LE COMPTE EST BON par jojolemariole
STRING TO (STRING) INT par maximelien
Source avec Zip ROMANOP : UN UTILITAIRE POUR LES NOMBRES ROMAINS (CONVERSION... par vladmanchev

Commentaires et avis

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!

Commentaire de jndis le 21/01/2012 14:25:27

L'algorithme ne respecte pas les conventions de Notation romaine voir http://fr.wikipedia.org/wiki/Num%C3%A9ration_romaine

dans l'exemple VV donne 10 alors que cette notation est incorrecte

jndisanze

 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 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 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 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 exercice java [ par kahru ] <d applets, écouteurs d'évènement [ par hiera ] Bonjour, je suis un débutant en développement java et jaimerai savoir comment je pourrais écrire un programme permettant à l'utilisateur de saisir un


Nos sponsors


Sondage...

CalendriCode

Février 2012
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
272829    

Consulter la suite du CalendriCode

 
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

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 3,526 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales