begin process at 2012 02 07 09:23:49
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Chaîne de caractères

 > STR2LONG - MAJ

STR2LONG - MAJ


 Information sur la source

Note :
Aucune note
Catégorie :Chaîne de caractères Niveau :Débutant Date de création :19/06/2003 Date de mise à jour :20/06/2003 19:38:33 Vu / téléchargé :1 966 / 57

Auteur : Skyman

Ecrire un message privé
Site perso
Commentaire sur cette source (9)
Ajouter un commentaire et/ou une note

 Description

IT is back !

encore plus fort,
encore plus rapide,
encore plus simple,
encore plus beau,
et avec un programmeur encore plus content !


voila le remake de str2long.
j ai rajoute math.h pour les puissances

grand merci a ceux qui m'ont aide a le refaire avec de percieux conseils.

quand j'y repense c'est vrai que ce que j'ai fait c'etait un peu de la mmmm..... (chut c po poli :)


L0L0

Source

  • #include <stdio.h>
  • #include <string.h>
  • #include <math.h> // powaaaaaaaa
  • // WAAIIIII
  • // J'ai trouvez comment calculer les puissances
  • // en titillant math.h
  • // c'est pow(nombre,exposant);
  • // pour info les valeur absolues des long
  • #define SIG_MIN -2147483648 // signe min
  • #define SIG_MAX 2147483647 // signe max
  • #define UNSIG_MIN 0 // pas signe nul
  • #define UNSIG_MAX 4294967295 // pas signe max
  • int is_chiffre(char car);
  • int car_chiffre(char car);
  • unsigned long chaine_nombre(char *chaine);
  • int verifier_chaine(char *chaine);
  • int main(int argc, char *argv[]){
  • char *chaine = ""; // chaine
  • unsigned long nombre; // nombre
  • printf("note de l'auteur :\n"); // eko
  • printf("il n'y a qu'en faisant des erreurs qu'on apprend\n"); // eko
  • printf("alors merci a ceux qui on m'ont aide a 'reparer' l'ancienne source"); // eko
  • if(argc != 2){ // 2 arguments
  • printf("utilisation : conv [nombre]"); // eko
  • return 0; // exit
  • }
  • if(!verifier_chaine(argv[1])){ // pas un nombre
  • printf("erreur : la valeur doit etre numerique."); // eko
  • return 0; // exit
  • }
  • chaine = argv[1]; // recupere la chaine
  • printf("Chaine : %s\n", chaine); // eko
  • nombre = chaine_nombre(chaine); // convertir
  • printf("Nombre : %d\n", nombre); // eko
  • }
  • // fonction de convertisassionnement
  • unsigned long chaine_nombre(char *chaine){
  • unsigned long resultat = 0;// nombre final
  • unsigned long nombre = 0; // avant les E10
  • int i; // boucle
  • int j; // boucle
  • int len = strlen(chaine); // longueur de la chaine
  • for(i = 0; i < len; i++){ // pour chaque car
  • nombre = 0; // initialise
  • // prend la valeur numerique du car en partant de droite
  • // note :
  • // j'ai pas compris :
  • // faire un pointeur sur une chaine de caractere
  • // puis l'incrementer au lieu de faire a chaque fois [i]
  • nombre = car_chiffre(chaine[len - i - 1]);
  • nombre *= pow(10,i); // puissance de 10
  • resultat += nombre; // ajoute
  • }
  • return resultat; // retourne le nombre final (long)
  • }
  • // verifie si tous les caractere sont des chiffres
  • int verifier_chaine(char *chaine){
  • int i; // boucle
  • for(i = 0; i < strlen(chaine); i++){ // pour chaque car
  • if(!is_chiffre(chaine[i])){ // si pas chiffre
  • return 0; // bye ...
  • }
  • }
  • return 1;
  • }
  • // verifie si le caractere est un chiffre
  • int is_chiffre(char car){
  • if(car >= '0' && car <= '9'){
  • return 1; // oui
  • }else{
  • return 0; // non
  • }
  • }
  • // convertion du caractere en chiffre
  • int car_chiffre(char car){
  • // wesh merci a JCDjcd
  • // ca c'est un truc auquel j'aurai jamais pense
  • // comme on a deja verifie que c'est un chiffre
  • // on retourne la valeur du car moins celle de 0
  • return car - '0';
  • }
#include <stdio.h>
#include <string.h>
#include <math.h> // powaaaaaaaa


// WAAIIIII
// J'ai trouvez comment calculer les puissances
// en titillant math.h
// c'est pow(nombre,exposant);



// pour info les valeur absolues des long
#define SIG_MIN     -2147483648 // signe min
#define SIG_MAX     2147483647   // signe max
#define UNSIG_MIN   0            // pas signe nul
#define UNSIG_MAX   4294967295   // pas signe max

int is_chiffre(char car);
int car_chiffre(char car);
unsigned long chaine_nombre(char *chaine);
int verifier_chaine(char *chaine);

int main(int argc, char *argv[]){
    
    char *chaine = "";  // chaine
    unsigned long nombre; // nombre
    
    printf("note de l'auteur :\n"); // eko
    printf("il n'y a qu'en faisant des erreurs qu'on apprend\n"); // eko
    printf("alors merci a ceux qui on m'ont aide a  'reparer' l'ancienne source"); // eko
        
    if(argc != 2){ // 2 arguments
        printf("utilisation : conv [nombre]"); // eko
        return 0;  // exit
    }
    
    if(!verifier_chaine(argv[1])){ // pas un nombre
        printf("erreur : la valeur doit etre numerique."); // eko
        return 0;  // exit
    }
    
    chaine = argv[1]; // recupere la chaine
    
    printf("Chaine : %s\n", chaine); // eko

    nombre = chaine_nombre(chaine);  // convertir 

    printf("Nombre : %d\n", nombre); // eko
    
}

// fonction de convertisassionnement
unsigned long chaine_nombre(char *chaine){
    
    unsigned long resultat = 0;// nombre final
    unsigned long nombre = 0;  // avant les E10
    int i; // boucle
    int j; // boucle
    int len = strlen(chaine);  // longueur de la chaine

    for(i = 0; i < len; i++){  // pour chaque car
        nombre = 0; // initialise
        // prend la valeur numerique du car en partant de droite
        
        // note :
        // j'ai pas compris :
        // faire un pointeur sur une chaine de caractere 
        // puis l'incrementer au lieu de faire a chaque fois [i]
        nombre = car_chiffre(chaine[len - i - 1]);
        nombre *= pow(10,i); // puissance de 10
        resultat += nombre;  // ajoute
    }

    return resultat; // retourne le nombre final (long)

}

// verifie si tous les caractere sont des chiffres
int verifier_chaine(char *chaine){
    int i; // boucle
    for(i = 0; i < strlen(chaine); i++){ // pour chaque car
        if(!is_chiffre(chaine[i])){      // si pas chiffre
            return 0; // bye ...
        }
    }
    return 1;
}

// verifie si le caractere est un chiffre
int is_chiffre(char car){
    if(car >= '0' && car <= '9'){
        return 1; // oui
    }else{
        return 0; // non
    }
}

// convertion du caractere en chiffre
int car_chiffre(char car){
    // wesh merci a JCDjcd
    // ca c'est un truc auquel j'aurai jamais pense
    
    // comme on a deja verifie que c'est un chiffre
    // on retourne la valeur du car moins celle de 0
    return car - '0';
}
    
  


 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Sources du même auteur

Source avec Zip ASSEMBLEUR (EDITEUR/COMPILATEUR)
Source avec Zip BINAIRE
Source avec Zip MD5

 Sources de la même categorie

Source avec Zip [C] WD_STRING V2.2 par cyberripper
Source avec Zip LES STRING EN C, AFFECTATION, CONCATÉNATION, SPLIT, ... par appranting
Source avec Zip [C] WD_STRING V1.9 par cyberripper
Source avec Zip LIBRAIRIE LANGUAGES par astro53
FONCTION : CHAR * AJUSTERTAILLECHAINE() par Rockanos

Commentaires et avis

Commentaire de BruNews le 19/06/2003 22:46:26 administrateur CS

atoi() retourne un 32 bits signe et non 8 bits.
Faudrait aussi nettement ameliorer ton algo, car_chiffre(char car) est une calamite.
Je te laisse trouver pourquoi. Au boulot.
ciao...

Commentaire de NitRic le 20/06/2003 02:51:11

et aussi, essaie de ne pas appeler strlen à toute les fois, stocke la longueur de la chaine dans une var, ca va être beaucoup, beaucoup, beaucoup, beaucoup, beaucoup, .... plus rapide!!!

dans ton for(), strlen est appeler à chaque tour de boucle donc il doit recalculer la longueur de la chaine à chaque fois ...

et en passant, je dit ca comme ca mais il existe pas seulement atoi() pour les int ... il y à aussi atol() pour les long ... atof() pour les double etc ... et si je peut me permettre, il y à une facon beaucoup beaucoup plus rapide et courte de faire ce genre de convertion ...



~(.::  NitRic  ::.)~

Commentaire de JCDjcd le 20/06/2003 10:00:19

Voici comment reprogrammer des fonctions !!!
***************************
int is_chiffre(char car)
{
return (car &gt;= '0' && car &lt;= '9');
}
***************************
He oui en une ligne, et infiniment plus rapide !

La seconde fonction :
*****************************
int car_chiffre(char car)
{
return car - '0';
}
***********************
He oui encore une ligne et encore infiniment plus rapide !



Il ne faut pas utiliser les switch a gogo !

Commentaire de JCDjcd le 20/06/2003 10:02:27

Ah oui, tu pourrais faire un pointeur sur une chaine de caractere puis l'incrementer au lieu de faire a chaque fois [i] !

Commentaire de JCDjcd le 20/06/2003 10:03:45

nombre = nombre + nombre_temp; // ajoute

Ca se programme :
nombre += nombre_temp; // ajoute

Commentaire de JCDjcd le 20/06/2003 10:06:12

Les 'break' juste apres des 'return' c'est super util !

Et je ne comprend pas pourquoi tu as besoin de 2 boucles pour convertir une chaine en un monbre ?

Commentaire de BruNews le 20/06/2003 10:17:37 administrateur CS

donc maintenat qu'on t'a tout dit,
nouveau cahier des charges:
unsigned long chaine_nombre(char *chaine){
    unsigned long nombre = 0;       // nombre final
// AUCUN strlen utile
// AUCUN appel de fonction externe
// 1 SEULE boucle par pointeur et valeur directe en sortie

    return nombre; // retourne le nombre final (long)
}

Nous attendons la nouvelle mouture.
ciao...

Commentaire de Skyman le 20/06/2003 12:37:00

cool ! Merci pour tout ces commentaire !
ca fait plaisir et ca motive! :-D
note : je ne savais pas que atol(); existait ...
on m'avait parle que de atoi();

je sais que j'ai un peu abuse avec les switch (lol :)
et que les break; apres return ca sert pas vraiment ...

les 2 boucle pour convertir une chaine en nombre c'est pour les puissance 10 et je sais pas faire les puissances en c !
selon sa position il multiplie par 10

promis je refais ca tout de suite.

Commentaire de BruNews le 21/06/2003 18:07:51 administrateur CS

unsigned long chaine_nombre(char* source)
{
  char *c = source;
  unsigned long n = 0;
  while(*c &gt;= 48 && *c &lt;= 57) {
    n *= 10;
    n += (*c - 48);
    c++;
  }
  return n;
}

ciao...

 Ajouter un commentaire




Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Février 2012
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
272829    

Consulter la suite du CalendriCode

Photothèque

 
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,619 sec (3)

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