begin process at 2010 09 06 05:12:22
  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é :7 694 / 154

Auteur : dje_jay

Ecrire un message privé
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

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

Source avec Zip Source avec une capture TUTORIAL MORPION DÉBUTANT par jojolemariole
Source avec Zip RC4 BY SKYNET par kingcherchell
Source avec Zip Source avec une capture EDITEUR DE COURBES par jojolemariole
Source avec Zip Source avec une capture JEU DE LA VIE par jojolemariole
Source avec Zip Source avec une capture OUTILS STATISTIQUES AVEC REPRÉSENTATION GRAPHIQUE (RÉGRESSIO... par Julien39

 Sources en rapport avec celle ci

STRING TO (STRING) INT par maximelien
STRING TO (STRING) HEXA par maximelien
Source avec Zip TRANSFORMATION NOMBRE EN LETTRE par smarticu
Source avec Zip ROMANOP : UN UTILITAIRE POUR LES NOMBRES ROMAINS (CONVERSION... par vladmanchev
CRIBLE D'ERATOSTHENE par chabacha

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!

 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 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 jeu des chiffres et des lettres [ par yrifka ] slt,j'ai un projet concernant l'interface graphique du jeu des chiffres et des lettres mais je suis bloquée en 2 points:le 1er à propos du chronomètre chronometre dans un jeu chiffres et des lettres [ par yrifka ] salut je suis entrain de programmer une interface graphique du jeux des chiffres et des lettres(en java, bibliothèque swing)et je veux inclure un chro 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


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Septembre 2010
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
27282930   

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 : 0,515 sec (4)

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