• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Java - QuickSort

Object Storage Arubacloud
0 głosów
410 wizyt
pytanie zadane 14 marca 2016 w Java przez Kapi2222 Obywatel (1,220 p.)
zmienione kategorie 14 marca 2016 przez Arkadiusz Waluk

Hej, próbuje posortować metodą QuickSort tablicę wypełnioną losowymi liczbami. Jestem już blisko ale nie mogę wyświetlić na ekran posortowanej już tablicy. Myślę i myślęi nie wiem jak to napisać :D Zerknie ktoś na kod i mi pomoże ? :)


import java.util.Scanner;
import java.util.Random;

public class QuickSort {

    static Scanner in = new Scanner(System.in);
    static Random r = new Random();
    
    
    public static void main(String[] args) {
        
        
        System.out.println("Podaj ilość liczb do posortowania: ");
        int w = in.nextInt();
        int [] MojaTablica = new int[w];
    
        
        sleep(2000);
        System.out.format("Tablica składa się z %d nieposortowanych elementów\n", MojaTablica.length);
        //Tworzenie losowej tablicy liczb
     // "Przejście" przez całą tablicę i wypełnienie jej liczbami losowymi
        for(int i=0; i<MojaTablica.length; i++)
            MojaTablica[i]=r.nextInt(100)+1;
 
        // Wyświetlenie zawartości całej tablicy (każdy element z osobna)
        for(int i=0; i<MojaTablica.length; i++)
            System.out.println(MojaTablica[i]);
        
 
        
       System.out.println("Za 3 sekundy rozpocznie się sortowanie QuickSort ");
       sleep(3000);
       quickSort(MojaTablica, 0, MojaTablica.length-1);
       System.out.println(MojaTablica);
        
            
        }
        
        public static void sleep(int time){
            try {Thread.sleep(time);}
            catch(Exception e) {}
                }

    
    //Sortowanie QuickSort
        public static void quickSort (int [] arr, int left, int right){
            int a = left;
            int b = right;
            int temp;
            int pivot = arr[(left+right)/2];
            
            //Proces partycjonowania
            while (a<=b){
                while (arr[a]<pivot)
                    a++;
                if (a<=b){
                    temp=arr[a];
                    arr[a]=arr[b];
                    arr[b]=temp;
                    a++;
                    b--;
                }
            }
            //powtarzanie procesu
            if (left<b)
                quickSort(arr,left,b);
            if (a<right)
                quickSort(arr,a,right);
            
        }
        
}


 

Odrazu ,żeby nikt nie musiał szukać powiem ,że błąd jest w linijce System.out.println(MojaTablica);. Ale nie wiem jak mam zrobić żeby program wyświetlił posortowaną już tablicę. Bo nieposortowaną ale wypełnioną już liczbami to wyświetla. :)

1 odpowiedź

0 głosów
odpowiedź 14 marca 2016 przez Mar Cin Dyskutant (8,900 p.)
edycja 14 marca 2016 przez Mar Cin
Tak w ogóle to nie lepiej było Ci użyć klasy Arrays?Natomiast do wyświetlenia już posortowanej tablicy proponuje użyć pętli for each :)
komentarz 14 marca 2016 przez Kapi2222 Obywatel (1,220 p.)
Jestem początkujący i prawdę mówiąc nie poznałem jeszcze jak działa ta klasa :)
komentarz 14 marca 2016 przez Mar Cin Dyskutant (8,900 p.)
Stwórz obiekt klasy Arrays,i użyj metody sort(),sortuje tablice używając własnie sorotowanie szybkiego :)
komentarz 14 marca 2016 przez Kapi2222 Obywatel (1,220 p.)
Dzięki to jest dobra rada :) Tylko ogólnie będę testował też inne rodzaje sortowań i czas ich wykonania. A są też inne metody ,dla innych sortowań? :D Np. dla heapsorta czy bubblesorta? Bo jeśli nie to i tak będę musiał robić osobną funkcję do tego :P A nie wiesz ,gdzie tu mam błąd ? Bo może coś mam źle w tej funkcji quicksort?
komentarz 14 marca 2016 przez Kapi2222 Obywatel (1,220 p.)
Dzięki bardzo za pomoc :) Już wiem co było nie tak. Po prostu zapomniałem dodać pętle ,która wypisałaby te wartości z tablicy :P Obydwa sposoby działają :) Mam jeszcze takie pytanie :) Tą metodą mogę sortować tylko rosnąco czy mogę też malejąco? Jeśli tak to jak to zrobic?
komentarz 14 marca 2016 przez Mar Cin Dyskutant (8,900 p.)

Poczytaj o klasie Arrays,jest wszystko dość szczegółowo opisane,http://javastart.pl/static/klasy/arrays-operacje-na-tablicach/ tutaj masz jedno źródło przykładowe:)Do przeglądanie elementów tablicy tak jak Ci pisałem staraj się używać pętli for each.

Podobne pytania

0 głosów
1 odpowiedź 149 wizyt
pytanie zadane 7 grudnia 2015 w Java przez mareki Nowicjusz (180 p.)
0 głosów
0 odpowiedzi 182 wizyt
pytanie zadane 25 maja 2020 w Java przez miko98 Nowicjusz (150 p.)
0 głosów
3 odpowiedzi 1,230 wizyt
pytanie zadane 4 października 2015 w Java przez uczeń1998 Obywatel (1,930 p.)

92,576 zapytań

141,426 odpowiedzi

319,652 komentarzy

61,961 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...