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

Java - QuickSort

VPS Starter Arubacloud
0 głosów
405 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ź 146 wizyt
pytanie zadane 7 grudnia 2015 w Java przez mareki Nowicjusz (180 p.)
0 głosów
0 odpowiedzi 179 wizyt
pytanie zadane 25 maja 2020 w Java przez miko98 Nowicjusz (150 p.)
0 głosów
3 odpowiedzi 1,226 wizyt
pytanie zadane 4 października 2015 w Java przez uczeń1998 Obywatel (1,930 p.)

92,455 zapytań

141,263 odpowiedzi

319,099 komentarzy

61,854 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...