IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C Discussion :

petit problème sur les grand entiers en c


Sujet :

C

  1. #1
    Membre à l'essai
    Inscrit en
    Avril 2010
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 17
    Points : 13
    Points
    13
    Par défaut petit problème sur les grand entiers en c
    Bonjour,
    c'est ma premiere participation dans ce forum,j'ai un projet sur la cryptographie,je dois implemanter le cryptsystème elgamal en C,le problème c'est que le type int ne me permet de manipuler des très grand nombres.
    y'a t-il un type ou une biblio qui permet ça?
    merci d'avance de m'aider

  2. #2
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    Tu peux implémenter tes propres types entier, ou un truc isomorphe. J'ai fait une démo (méthode naïve) ici, mais il y a aussi la bibliothèque GMP, plus aboutie.

  3. #3
    Membre à l'essai
    Inscrit en
    Avril 2010
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 17
    Points : 13
    Points
    13
    Par défaut
    comment installer cette bibliothèque et l'utiliser ?
    j'ai fait une mis à jour dans dev-c++ et j'ai ajouté GMP,mais quand j'utilise des fonctions comme pow(a,b),il me demande de la définir.
    je l'ai télechargé de http://gmplib.org/, mais comment l'installer?

  4. #4
    Invité
    Invité(e)
    Par défaut
    Bonjour, tu as un tutoriel en français sur ce site http://coder.tuxfamily.org/programma...aller_GMP.html

    Ensuite deux règles de bases qui peuvent éviter d'avoir des problèmes :

    Quand tu crées une variable gmp (mpz_t) penses à l'initialiser et ensuite à l'effacer (comme un malloc/free).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    #include <stdio.h>
    #include <stdlib.h>
    #include <gmp.h>
     
    int main(void)
    {
    	mpz_t a,b,c;
    	mpz_init(a);
    	mpz_init_set_ui(b, 10);
    	mpz_init_set_str(c, "31", 10);
     
    	mpz_add(a,b,c);
    	mpz_add_ui(a, a, 1);
    	gmp_printf("La réponse ultime est : %Zd\n", a);
     
    	mpz_clear(a);
    	mpz_clear(b);
    	mpz_clear(c);
     
    	return 0;
    }

  5. #5
    Membre à l'essai
    Inscrit en
    Avril 2010
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 17
    Points : 13
    Points
    13
    Par défaut
    Merci, je vais essayer

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Petit problème sur les pointeurs :
    Par bertry dans le forum Débuter
    Réponses: 9
    Dernier message: 15/03/2011, 10h18
  2. Réponses: 1
    Dernier message: 02/03/2008, 22h04
  3. Réponses: 3
    Dernier message: 12/08/2007, 16h49
  4. petit problème sur les listes chaînées
    Par poche dans le forum C
    Réponses: 14
    Dernier message: 19/03/2007, 16h53
  5. Petite question sur les performances de Postgres ...
    Par cb44 dans le forum PostgreSQL
    Réponses: 5
    Dernier message: 13/01/2004, 13h49

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo