CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

Need codeur C pour simple éclairage

cardan
cardan
Niveau 10
04 septembre 2012 à 22:31:59

J'ai, pour la deconne, fait un programme pour tester la conjecture de syracuse, ou suite des grelons. :hap:
Ca marche comme ça :
On entre un chiffre
Si pair on divise par 2 . (x/2)
Si impair on multiplie par trois et ensuite on ajoute 1. ((x*3)+1)

Bref logiquement tous les nombres devraient rentrer dans la boucle 124124124124124 ...........

Mais pour des nombre de l'ordre de 11 ou 12 chiffres et plus, ça marche plus

EXPLICATION ? :question:

+ Mon code pour deceler une erreur :

:d) :d) :d)

  1. include <stdio.h>
  2. include <stdlib.h>

int main()
{
int nombre = 0, nmbdecoup = 0;
printf(" entrez le nombre que vous voulez tester");
scanf("%d", &nombre);

do
{
if(nombre % 2 == 0)
nombre = nombre/2;
else
nombre = nombre*3+1;
printf("%d %deme coup\n", nombre, nmbdecoup);
nmbdecoup++;

} while(nombre != 1);

return 0;
}

:g) :g) :g)

( PS : je debute )

cardan
cardan
Niveau 10
04 septembre 2012 à 22:33:32

Ha oui, et quand je dis que ça ne marche plus c'est dans le sens boucle infinie :-(

was666
was666
Niveau 7
04 septembre 2012 à 22:43:25

Salut,

20ans que j'ai pas posté sur ce forum mais je peux t'éclaircir.
Tu utilises des variables de type integer, soit de -2147483647 à 2147483647 donc si tu mets une valeur qui dépasse ce nombre tu vas faire un overflow ( ca provoquera un changement de signe parce que ça va faire le bordel dans les bits qui représentent le nombre (pour simplifier haha) )

Tu as plusieurs solutions, soit tu utilises un long int, ou unsigned long int (ca te permettra d'avoir une marge supplémentaire en plus, mais attention l'unsigned ne prend que les nombres positifs, son bit qui n'est plus utilisé pour stocker le signe permet de stocker des nombres plus grand)

Soit tu passes par une chaine, en stockant chaque nombre dans une partie de ta chaine par exemple :

char str toto = ["1234"];
char str tata = ["1232"];

Dans ce cas la toto[0] == 1, toto[1] == 2, etc..

Par contre tu ne peux pas faire de calcul sur ta chaine, il faut la poser comme au primaire en passant par chaque case de ta chaine.

cardan
cardan
Niveau 10
08 septembre 2012 à 21:32:37

Reponse tardive pour cause d'oubli de topic ( :noel: )

Mais merci beaucoup pour vos reponses !

Sous forums
  • Aide à l'achat Mac
  • Macintosh
  • Création de Jeux
  • Programmation
  • Création de sites web
  • Linux
  • Internet
  • Steam Deck
  • Hardware