内容简介:经典排序算法及其 Java 实现
「博客搬家」原地址:简书 原发表时间: 2017-08-17
网上有很多 排序 算法的总结,不过有很多缺点,比如有些根本就是错的,无法通过测试用例,有些过于冗长。所以我总结了一套短小精悍的 Java 实现,经测试,该套实现可通过牛客网的关于此的所有测试用例。
1. 冒泡排序
public class BubbleSort implements KySort {
public void kySort(int[] a, int size) {
for (int i = 0; i < size - 1; i++) {
for (int j = 0; j < size - i - 1; j++) {
if (a[j] > a[j + 1]) {
swap(a, j, j + 1);
}
}
}
}
}
2. 插入排序
public class InsertSort implements KySort {
public void kySort(int[] a, int size) {
for (int i = 1; i < size; i++) {
int temp = a[i];
int j = i;
while (j > 0 && a[j - 1] > temp) {
a[j] = a[j - 1];
j--;
}
a[j] = temp;
}
}
}
3. 选择排序
public class SelectSort implements KySort {
public void kySort(int[] a, int size) {
for (int i = 0; i < size - 1; i++) {
int min = i;
for (int j = i + 1; j < size; j++) {
if (a[j] < a[min]) {
min = j;
}
}
if (i != min) {
swap(a, i, min);
}
}
}
}
4. 堆排序
public class HeapSort implements KySort {
public void kySort(int[] a, int n) {
for (int i = n / 2; i >= 0; i--) {
heapAdjust(a, i, n - 1);
}
for (int i = n - 1; i > 0; i--) {
swap(a, 0, i);
heapAdjust(a, 0, i - 1);
}
}
/**
* @param index 父节点索引
* @param n 尾节点索引
*/
private void heapAdjust(int[] a, int index, int n) {
int temp = a[index];
for (int child = index * 2 + 1; child <= n; child = index * 2 + 1) {
if (child < n && a[child] < a[child + 1]) {
child++;
}
if (temp > a[child]) break;
a[index] = a[child];
index = child;
}
a[index] = temp;
}
}
5. 归并排序
public class MergeSort implements KySort {
public void kySort(int[] a, int size) {
sort(a, 0, size - 1, new int[a.length]);
}
private void sort(int[] a, int left, int right, int[] temp) {
if (left >= right) return;
int mid = (left + right) / 2;
sort(a, left, mid, temp);
sort(a, mid + 1, right, temp);
merge(a, left, mid, right, temp);
}
private void merge(int[] a, int left, int mid, int right, int[] temp) {
int k = left;
int i = left;
int j = mid + 1;
while (i <= mid && j <= right) {
if (a[i] < a[j]) {
temp[k++] = a[i++];
} else {
temp[k++] = a[j++];
}
}
while (i <= mid) {
temp[k++] = a[i++];
}
while (j <= right) {
temp[k++] = a[j++];
}
while (left <= right) {
a[left] = temp[left];
left++;
}
}
}
6. 快速排序
public class QuickSort implements KySort {
@Override
public void kySort(int[] a, int size) {
quickSort(a, 0, size - 1);
}
private void quickSort(int[] a, int left, int right) {
if (right - left < 2) {
if (a[left] > a[right])
swap(a, left, right);
return;
}
int p = middleBy3(a, left, right);
quickSort(a, left, p - 1);
quickSort(a, p + 1, right);
}
private int middleBy3(int[] a, int left, int right) {
int p = (left + right) / 2;
int end = right;
if (a[left] > a[p]) swap(a, left, p);
if (a[left] > a[right]) swap(a, left, right);
if (a[p] > a[right]) swap(a, p, right);
int temp = a[p];
swap(a, p, right);
while (true) {
while (a[++left] < temp) ;
while (a[--right] > temp) ;
if (left >= right) break;
else swap(a, left, right);
}
swap(a, left, end);
return left;
}
}
7. 附录
7.1 交换方法
public class Util {
public static void swap(int[] a, int i, int j) {
int k = a[i];
a[i] = a[j];
a[j] = k;
}
}
7.2 基于策略模式的主程序实现
public class SortMain {
private static KySort sorter;
private int[] a;//定义一个数组
private SortMain(int... values) { //构造函数
a = values;
}
public static void main(String[] args) {
setSorter(new QuickSort());
SortMain arr;
arr = new SortMain(5, 4, 3, 2, 1, 0);
arr.display();
arr.kySort();
arr.display();
System.out.println("--------");
arr = new SortMain(54, 35, 48, 36, 27, 12, 44, 44, 8, 14, 26, 17, 28);
arr.display();
arr.kySort();
arr.display();
System.out.println("--------");
arr = new SortMain(32, 103, 24, 88, 95, 70, 97, 15, 102, 6, 79, 46, 51, 37, 93, 108, 9, 58, 53, 58, 79, 36, 58, 91, 78, 58, 61, 81); //初始化数组
arr.display();
arr.kySort();
arr.display();
}
private static void setSorter(KySort sorter) {
SortMain.sorter = sorter;
}
private void display() {
for (int i : a) { //遍历数组中每一个元素
System.out.print(i + " "); //展示
}
System.out.println();
}
private void kySort() {
sorter.kySort(a, a.length);
}
}
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 算法之常见排序算法-冒泡排序、归并排序、快速排序
- 排序算法之冒泡排序改进算法
- 快速排序算法,C语言快速排序算法深入剖析
- 排序算法下——桶排序、计数排序和基数排序
- 数据结构和算法面试题系列—排序算法之快速排序
- 数据结构和算法面试题系列—排序算法之基础排序
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
微商团队管理实战手册
杜一凡 / 人民邮电出版社 / 2015-11 / 45.00元
回顾淘宝,用了10年时间才发展了不到1000万的卖家,再看微商,其仅一年时间就拥有了超过1000万的卖家。进入2015年,微商的发展之路虽有小坎坷,但前景依然被看好。然而任何一个想要做大、做强的微商都要以团队形式来发展,独立的个体只会举步维艰。 本书全面解读微商团队管理的营销书。全书共分为六章,分别从微商团队的商业秘密、微商团队的战略布局、管理基本功、建立高效团队、精通管理工具、未来发展等方......一起来看看 《微商团队管理实战手册》 这本书的介绍吧!