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

[Java] Débutant, problème math.random

gontran_veinard
gontran_veinard
Niveau 6
27 octobre 2010 à 15:01:12

Bonjour, je début en Java (et en programmation d'ailleurs), en bossant sur netbeans.

Voici l'énoncé:

2. Tri descendant d'un tableau

* On sait grâce à la méthode Arrays.sort() trier un tableau dans l'ordre ascendant, à vous de faire une habile permutation des éléments pour avoir le tableau en ordre descendant. Créez un tableau de 30 nombres entiers aléatoires entre 1 et 1000 et faites-en le tri descendant.

Voilà donc le code que j'écris afin pour commencer d'avoir un tableau trié dans l'ordre:

int[] tableau1 = new int[29];
for (int i = 0; i < tableau1.length; i++) {
tableau1[i] = (int) (Math.random() * 1000) + 1;
Arrays.sort(tableau1);
System.out.print(tableau1[i] + " ");
}

Problème, j'obtiens des zéros dans mon tableau. L'erreur doit donc être très bête, mais j'ai beau cherché je ne la trouve pas.

De plus, auriez-vous une idée d'habile permutation pour trier dans l'ordre décroissant?

Voilà, merci pour toute aide.

String[]args
String[]args
Niveau 23
27 octobre 2010 à 19:31:39

La méthode de tri s'utilise en dehors de la boucle. :o))
D'abord tu remplis le tableau, puis tu tries, et tu refais une boucle pour afficher. x)

dnob700
dnob700
Niveau 10
27 octobre 2010 à 21:31:12

Encore une question débile... Si tu veux trier un tableau dans un autre sens que celui par défaut, il faut fournir une fonction de comparaison à sort (un Comparator) pour qu'il fasse le tri dans le sens que tu veux.

anibale
anibale
Niveau 10
04 novembre 2010 à 15:57:30

C'est normal que tu n'obtiennes que des zéro au début.
Ton "int[] tableau1 = new int[29];" va t'initialiser un tableau de 29 int qu'il initialise à zéro.

Ensuite, tu replace chaque indice par un nombre au hasard et tu tries. Bah c'est normal que les premiers éléments affichés seront ceux qui valent 0 (du tableau initialisé).

En plus tu tries dans ta boucle, comme disent les autres, ça se fait au dehors.
Parce que là, tu écrases des éléments qui avaient été rangés.

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