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

aide en C

noms57
noms57
Niveau 7
18 octobre 2007 à 18:05:38

Salut à tout le monde du forum. Voila je suis débutant en programmation et j´essaye de faire un ptit programme en C me permettant de trouver le premier nombre pair d´un tableau. Mais j´ai beau m´arracher les cheveux, je n´arrive pas à trouve les quelques erreurs...
Si quelqu´un aurait une idée du pk du comment ca serait sympa de votre part.
Merci déja à tous ceux qui pourraient m´aider

/*
Recherche de la position d´un élément vérifiant une caractéristique

Ici, on déterminera la position d´un élément en fonction
de la caractéristique " premier pair". Il faudra trouver
le premier pair du tableau est afficher sa valeur

  • /
  1. define n 5

void main()

{

int i; //Entier: compteur d´itération
int tab[n]; //Entier: Tableau de n entiers

for(i=0;i<n;i++)
{
printf(" entrer la valeur desiree: ");
scanf("%d", &tab[i]);
}

do
{
i = i + 1;
}while ((tab[i]%2 != 0)||(i != n));

if(tab[i]%2 == 0)
{
printf("%d", i);
}
else
{
printf("il n´y aucun élément pair dans votre tableau");
}

}

Fvirtman
Fvirtman
Niveau 10
18 octobre 2007 à 18:09:07

ça ne compile pas ? -> quelle est l´erreur de compile ?
ça plante ?
ou alors ça ne fait pas ce que ça devrait faire ? -> exemple ?

noms57
noms57
Niveau 7
18 octobre 2007 à 18:11:34

ben ca se compile bien, le programme se lance dans le console. Apres je peux rentrer mes valeurs dans le tableau et dès que les 5 valeurs sont rentrés, le programme bug et se ferme illico

Chaos_Clad
Chaos_Clad
Niveau 10
18 octobre 2007 à 18:13:52

Je me trompe peut-être mais ton for va initialiser i jusqu´à la valeur n puis ensuite tu rerentres dans une boule dépendant de i sans avoir remis ce dernier à 0.

for(i=0;i<n;i++)
{
printf(" entrer la valeur desiree: ");
scanf("%d", &tab[i]);
}

=> i = n

do
{

i = i + 1; => i = n+1

}while ((tab[i]%2 != 0)||(i != n)); // tab[n+1] ?? ? Connais pas, je plante.

Fvirtman
Fvirtman
Niveau 10
18 octobre 2007 à 18:35:04

++ Chaos_Clad :ok:

Chaos_Clad
Chaos_Clad
Niveau 10
18 octobre 2007 à 18:36:11

Tu as aussi plusieurs autres erreurs.
Dans ton do while tu incrémentes la valeur de i, donc s´il vaut 0, il vaudra 1, et la première case de ton tableau (n´oublie pas que ça commence à 0) ne sera pas vérifiée.
Ensuite, le test booléen que tu utilises dans le while est faux.

Suppose que tab[i] vale 8, il est évidemment pair, donc le %2 va renvoyer 0, mais i vaut 3, donc (i != n) va renvoyer 1, et étant donné que tu utilises un || et que 0 || 1 = 1, ton while va continuer à tourner, préfère donc un && et un opérateur d´inégalité.

Fais aussi attention à l´indentation, je te dis ça parce que je sais pas si c´est le cas étant donné la mise en page pourrie de JV.com, mais dès fois une bonne indentation du code peut te sauver la vie ^^

Voici la version corrigée :
http://rafb.net/p/ajg4KV47.html

noms57
noms57
Niveau 7
19 octobre 2007 à 14:27:37

merci à ts les 2 ^^

J´ai réussi à le faire d´une autre façon avant d´avoir ta version corrigée lol. en tout cas, merci

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