DarkHorse_pxf

导航

【算法与数据结构】冒泡、插入、归并、堆排序、快速排序的Java实现代码

详细过程就不表了,看代码吧

  1 import java.util.Arrays;
  2 
  3 public class Sort {
  4 
  5     
  6     static int swapTimes=0;
  7     public static void main(String[] args) {
  8         int[] numbers = { 7, 6, 5, 3, 1, 8, 9, 7, 1, 2 ,5};
  9         //*** BubbleSort Test ***
 10         //bubbleSort(numbers);
 11          
 12         //*** InsertSort Test ***
 13         //insertSort(numbers);
 14          
 15         //*** MergeSort Test ***
 16         //mergeSort(numbers);
 17         
 18         //*** HeapSort Test ***
 19         //heapSort(numbers);
 20         
 21         //*** QuickSort Test ***
 22         
 23         quickSort(numbers);
 24         System.out.println("result:"+Arrays.toString(numbers));
 25 
 26     }
 27 
 28     /*
 29      * 插入排序
 30      */
 31     public static void insertSort(int[] numbers) {
 32         System.out.println("InsertSort:"+Arrays.toString(numbers));
 33         if (numbers == null) {
 34             System.out.println("Invalid input!");
 35             return;
 36         }
 37         for (int i = 1; i < numbers.length; i++) {
 38             int temp=numbers[i];
 39             int j=i-1;
 40             for (; j >= 0&&numbers[j]>temp; j--) { //这个数大于比较数,就把这个数右移
 41                 numbers[j + 1] = numbers[j];
 42                 System.out.println(Arrays.toString(numbers)+"---temp="+temp);
 43             }
 44             numbers[j+1]=temp;    //把比较数赋值到正确位置
 45             System.out.println(Arrays.toString(numbers));
 46         }
 47     }
 48 
 49     /*
 50      * 冒泡排序
 51      */
 52     public static void bubbleSort(int[] numbers) {
 53         System.out.println("BubbleSort:");
 54         if (numbers == null) {
 55             System.out.println("Invalid input!");
 56             return;
 57         }
 58         for (int i = numbers.length - 1; i > 0; i--) {
 59             for (int j = 0; j < i; j++) {
 60                 if (numbers[j] > numbers[j + 1]) {
 61                     swap(numbers, j, j + 1);
 62                 }
 63             }
 64         }
 65         System.out.println("result:");
 66     }
 67     /*
 68      * 归并排序
 69      */
 70     public static void mergeSort(int[] numbers){
 71         if(numbers==null){
 72             System.out.println("Invalid input!");
 73             return;
 74         }
 75         mergeSort(numbers,0,numbers.length-1);
 76     }
 77     
 78     private static void mergeSort(int[] numbers, int start, int end) {
 79         if(start>=end){
 80             return;
 81         }
 82         int mid=(start+end)>>1;
 83         mergeSort(numbers, start, mid);
 84         mergeSort(numbers, mid+1, end);
 85         merge(numbers,start,mid,end);
 86         System.out.println(Arrays.toString(numbers)+"---mid="+mid);
 87     }
 88     /*
 89      * 合并两个有序数组 
 90      */
 91     private static void merge(int[] numbers, int start, int mid, int end) {
 92         int leftLength=mid-start+1;
 93         int rightLength=end-mid;
 94         int[] leftNumbers=new int[leftLength];
 95         int[] rightNumbers=new int[rightLength];
 96         for (int i = 0; i < leftLength; i++) {//将左边的元素赋给left数组
 97             leftNumbers[i]=numbers[start+i];
 98         }
 99         for (int j = 0; j < rightLength; j++) {//同理
100             rightNumbers[j]=numbers[mid+j+1];
101         }
102         int pLeft=0;
103         int pRight=0;
104         for(int index=start;index<=end;index++){//开始merge左右数组
105             if(pLeft==leftLength){    //当left数组合并完了,就直接赋值right数组
106                 numbers[index]=rightNumbers[pRight++];
107             }else if(pRight==rightLength){
108                 numbers[index]=leftNumbers[pLeft++];
109             }else{        //左右数组都没赋值完,就要比较大小
110                 if(leftNumbers[pLeft]<=rightNumbers[pRight]){
111                     numbers[index]=leftNumbers[pLeft++];
112                 }else{
113                     numbers[index]=rightNumbers[pRight++];
114                 }
115             } 
116         }
117     }
118     /*
119      * 堆排序
120      */
121     public static void heapSort(int[] numbers){
122         if(numbers==null){
123             System.out.println("Invalid input!");
124             return;
125         }
126         int[] heap=buildHeap(numbers);    //构造小顶堆
127         System.out.println("build Heap:"+Arrays.toString(heap));
128         int index=0;
129         while(!isHeapEmpty(heap)){
130             //注意,这里不能在前面的index++,因为会先算左括号内的++,造成传入的index+1
131             numbers[index]=popHeapTop(heap,index++);  
132             
133         }
134     }
135     //将堆顶元素pop出来
136     private static int popHeapTop(int[] heap,int index) {
137         int temp=heap[0];
138         int end=heap.length-1-index;
139         heap[0]=heap[end];        //将最后一个数移至堆顶
140         heap[end]=Integer.MAX_VALUE;
141         adjustHeap(heap, 0);    //调整堆
142         System.out.println("current Heap:"+Arrays.toString(heap));
143         return temp;
144     }
145 
146     private static boolean isHeapEmpty(int[] heap) {
147         if(heap[0]==Integer.MAX_VALUE){
148             return true;
149         }
150         return false;
151     }
152     /*
153      * 构造小顶堆
154      */
155     private static int[] buildHeap(int[] numbers) {
156         int[] heap=new int[numbers.length];
157         for(int i=0;i<heap.length;i++){
158             heap[i]=numbers[i];
159         }
160         for(int j=(heap.length>>1)-1;j>=0;j--){ //从有孩子的结点开始,从底向上维护堆
161             adjustHeap(heap,j);
162         }
163         return heap;
164     }
165     /*
166      * 维护堆
167      */
168     private static void adjustHeap(int[] heap, int j) {
169         int left=j<<1;
170         int right=(j<<1)+1;
171         int largest=j;
172         if(left<heap.length            //该左孩子下标必须在数组内
173                 &&heap[left]!=Integer.MAX_VALUE    //该元素必须未被覆盖
174                 &&heap[j]<heap[left]){    
175             largest=left;
176         }
177         if(right<heap.length
178                 &&heap[right]!=Integer.MAX_VALUE
179                 &&heap[largest]<heap[right]){
180             largest=right;
181         }
182         
183         if(largest!=j){
184             swap(heap, j, largest);
185             adjustHeap(heap, largest);  //继续往下调整
186         }
187         
188     }
189     
190     /*
191      * 快速排序
192      */
193     public static void quickSort(int[] numbers){
194         if(numbers==null){
195             System.out.println("Invalid input!");
196             return;
197         }
198         System.out.println("QuickSort:");
199         quickSort(numbers,0,numbers.length-1);
200     }
201     private static void quickSort(int[] numbers, int start, int end) {
202         if(start<end){
203             int mid=patition(numbers,start,end);
204             quickSort(numbers, start, mid-1);
205             quickSort(numbers, mid+1, end);
206         }
207         
208     }
209     /*
210      * 选一个数,将小于它的数放在左边,大于它的放在右边
211      */
212     private static int patition(int[] numbers, int start, int end) {
213         int small=start-1;
214         int index=start;
215         int temp=numbers[end]; //选择数组最后一个元素作为比较数
216         while(index<=end){
217             if(numbers[index]<temp){
218                 small++;
219                 if(index!=small){
220                     swap(numbers, small, index);
221                 }
222             }
223             index++;
224         }
225         swap(numbers, small+1, end);
226         return small+1;
227     }
228     /*
229      * 交换数组的两个元素
230      */
231     private static void swap(int[] numbers, int a, int b) {
232         int temp = numbers[a];
233         numbers[a] = numbers[b];
234         numbers[b] = temp;
235         System.out.println("current numbers:" +        //记录交换次数
236                 ""+Arrays.toString(numbers)+"----swap times:"+(++swapTimes));
237     }
238     
239     
240 
241 }

 

posted on 2015-03-29 10:53  DarkHorse_pxf  阅读(313)  评论(0编辑  收藏  举报