幾種經常使用排序算法代碼

  1 public class CheckSum {
  2 
  3     /**
  4      * 計算數組中數據以後爲sum的兩個數字
  5      * @param array
  6      * @param sum
  7      */
  8     public void findTheSum(int array[], int sum) {
  9 
 10         //Arrays.sort(array);
 11 
 12         int[] copy = new int[array.length];
 13 
 14         MergeOrder(array, copy, 0, array.length - 1);
 15 //        fastOrder(array, 0, array.length - 1);
 16         System.out.println(array);
 17         int row = 0, high = array.length - 1;
 18         while (row < high) {
 19 
 20             if (array[row] + array[high] > sum) {
 21                 high--;
 22             } else if (array[row] + array[high] < sum) {
 23                 row++;
 24             } else {
 25                 System.out.println(array[row] + " " + array[high]);
 26                 if (high - 1 >= 0 && array[high] == array[high - 1]) {
 27                     high--;
 28                     continue;
 29                 }
 30 
 31                 if (high - 1 >= 0 && array[row] == array[row + 1]) {
 32                     row++;
 33                     continue;
 34                 }
 35 
 36                 row++;
 37                 high--;
 38             }
 39 
 40         }
 41     }
 42 
 43 
 44 
 45     //小堆排序
 46 
 47     public void duiSortedOrder(int array[], int index,int len) {
 48 
 49         int tempt = array[index];
 50         for (int i = 2 * index + 1; i <= len; i = i * 2 + 1) {
 51             if(i<len&&array[i]>array[i+1]) i++;
 52             if(tempt<array[i]) break;
 53             array[index] = array[i];
 54             index = i;
 55         }
 56         array[index] = tempt;
 57     }
 58 
 59 
 60     //直接插入法
 61     public void InsertOrder(int array[]) {
 62 
 63         for (int i = 1; i < array.length; i++) {
 64             int tempt = array[i], j = i - 1;
 65             for (; j >= 0 && tempt < array[j]; j--) {
 66                 array[j + 1] = array[j];
 67             }
 68             array[j + 1] = tempt;
 69         }
 70     }
 71 
 72 
 73 
 74 
 75     /**
 76      * 歸併排序
 77      * @param array
 78      * @param copy
 79      * @param low
 80      * @param high
 81      */
 82     public void MergeOrder(int[] array, int[] copy, int low, int high) {
 83 
 84         if (low == high) return;
 85 
 86         int mid = (low + high) >> 1;
 87 
 88         MergeOrder(array, copy, low, mid);
 89 
 90         MergeOrder(array, copy, mid+1, high);
 91 
 92         //把元素聚合在一塊兒
 93         int left = low;
 94         int right = mid+1;
 95         int cindex = low;
 96         while (left<=mid && right <=high) {
 97 
 98             if (array[left] < array[right]) {
 99                 copy[cindex++] = array[left++];
100             } else {
101                 copy[cindex++] = array[right++];
102             }
103         }
104 
105         for (; left <= mid; ) {
106             copy[cindex++] = array[left++];
107         }
108 
109         for (; right <=high; ) {
110             copy[cindex++] = array[right++];
111         }
112 
113 
114         //把排序以後的元素放置到 array中
115 
116         for (int i = low; i < cindex; i++) {
117             array[i] = copy[i];
118         }
119         return;
120     }
121 
122 
123     /**
124      * 快速排序
125      *
126      * @param array
127      * @param row
128      * @param high
129      */
130     public void fastOrder(int[] array, int row, int high) {
131 
132         if (row < high) {
133             int mid = Order(array, row, high);
134             fastOrder(array, row, mid - 1);
135             fastOrder(array, mid + 1, high);
136         }
137 
138     }
139 
140 
141     public int Order(int[] array, int row, int high) {
142 
143         int tempt = array[row];
144 
145         while (row < high) {
146 
147             while (tempt < array[high] && high > row) {
148 
149                 high--;
150             }
151 
152             array[row] = array[high];
153 
154             while (tempt > array[row] && row < high) {
155                 row++;
156             }
157             array[high] = array[row];
158         }
159 
160         array[row] = tempt;
161         return row;
162 
163     }
164 
165 
166 
167      public static void main(String... args) {
168         CheckSum checkSum = new CheckSum();
169 
170         int[] params = new int[]{8, 7, 6, 5, 4, 3, 2};
171         for (int i = params.length / 2 - 1; i >= 0; i--) {
172             checkSum.duiSortedOrder(params, i,params.length-1);
173         }
174 
175         //輸出排序後的數據
176 
177         for (int i = 0; i <= params.length-1; i++) {
178             System.out.println(params[0]);
179             params[0] = params[params.length - 1 - i];
180             checkSum.duiSortedOrder(params, 0, params.length - 1 - i);
181         }
182 
183 
184         checkSum.InsertOrder(params);
185         System.out.println(params);
186 
187     }
188 }
相關文章
相關標籤/搜索