Computer >> 컴퓨터 >  >> 프로그램 작성 >> Java

반복적인 빠른 정렬을 위한 Java 프로그램

<시간/>

다음은 Iterative Quick Sort를 위한 Java 프로그램입니다 -

public class Demo{
   void swap_vals(int arr[], int i, int j){
      int temp = arr[i];
      arr[i] = arr[j];
      arr[j] = temp;
   }
   int partition(int arr[], int l, int h){
      int x = arr[h];
      int i = (l - 1);
      for (int j = l; j <= h - 1; j++){
         if (arr[j] <= x){
            i++;
            swap_vals(arr, i, j);
         }
      }
      swap_vals(arr, i + 1, h);
      return (i + 1);
   }
   void quick_sort(int arr[], int l, int h){
      int my_list[] = new int[h - l + 1];
      int top = -1;
      my_list[++top] = l;
      my_list[++top] = h;
      while (top >= 0){
         h = my_list[top--];
         l = my_list[top--];
         int p = partition(arr, l, h);
         if (p - 1 > l){
            my_list[++top] = l;
            my_list[++top] = p - 1;
         }  
         if (p + 1 < h){
            my_list[++top] = p + 1;
            my_list[++top] = h;
         }
      }
   }
   public static void main(String args[]){
      Demo my_ob = new Demo();
      int my_arr[] = { 34, 76, 41, 32, 11, 0 , 91, 102, -11};
      my_ob.quick_sort(my_arr, 0, my_arr.length - 1);
      int i;
      System.out.println("After iteratively performing quick sort, the array is ");
      for (i = 0; i < my_arr.length; ++i)
      System.out.print(my_arr[i] + " ");
   }
}

출력

After iteratively performing quick sort, the array is
-11 0 11 32 34 41 76 91 102

Demo라는 클래스에는 임시 변수를 사용하여 값을 교환하는 데 사용되는 'swap_vals', 피벗 값에 따라 배열을 두 부분으로 나누는 '파티션' 함수, 값을 피벗하고 이 값을 기준으로 배열의 값을 정렬합니다.

메인 함수에서 Demo 클래스의 인스턴스가 배열과 함께 생성됩니다. 이 배열에서 'quick_sort' 함수가 호출되고 출력이 콘솔에 표시됩니다.