begin process at 2010 02 10 05:55: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é :6 960 / 145

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 CLASSE MATRICE par frankladen11
Source avec Zip Source avec une capture RÉSOLUTION D'ÉQUATION GRÂCE AU CALCUL DES DÉTERMINANTS par frankladen11
Source avec Zip TYPE DE DONNÉES ABSTRAIT GRAPHE par smutsonberg
Source avec Zip Source avec une capture SIMPLEXE ET DUAL par MrRenaud
Source avec Zip ALGORITHME DE BELLMAN, CALCUL DES TEMPS AU PLUS TÔT ET RECHE... par michaelcourcy2005

 Sources en rapport avec celle ci

Source avec Zip ROMANOP : UN UTILITAIRE POUR LES NOMBRES ROMAINS (CONVERSION... par vladmanchev
CRIBLE D'ERATOSTHENE par chabacha
Source avec Zip TEST SUR NOMBRES PREMIERS par amundain
Source avec Zip LE COMPTE EST BON APPLET par oliverdev
Source avec Zip CONVERSION IMAGE par grand_jeanluc

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

Février 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728

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,749 sec (4)

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