7种排序算法
package com.org.momo.排序算法;
public class Sort {
public static void displayData(int[] data) {
for (int d : data) {
System.out.print(d + " ");
}
System.out.println("");
}
/**
* 快速排序:时间复杂度O(nlogn),最坏时间复杂度O(n2),平均时间复杂度O(nlogn),算法不具稳定性
思想:
基于冒泡排序,取第一个作为关键值a,用a与后面开始往前比较,遇到比a小
的则交换,依然乘此关键值为a,再用a与第一个数开始向后比较,遇到比a大的则
交换,最终的关键值将依然是最初的第一个元素的值,用此值将此无序序列分成两
部分,比它小的都在它前面,大的都在后面,然后用递归将前面和后面的分别用快
速排序进行处理,得到最终的有序序列.
*/
public static void quickSort(int[] src, int begin, int end) {
if (begin < end) {
int key = src[begin];
int i = begin;
int j = end;
while (i < j) {
while (i < j && src[j] > key) {
j--;
}
if (i < j) {
src[i] = src[j];
i++;
}
while (i < j && src[i] < key) {
i++;
}
if (i < j) {
src[j] = src[i];
j--;
}
}
src[i] = key;
quickSort(src, begin, i - 1);
quickSort(src, i + 1, end);
}
}
/**
* 冒泡排序算法:时间复杂度O(n2),算法具有稳定性,堆排序和快速排序算法不具
有稳定性,即排序后相同元素的顺序会发生变化
思想:
n个数,将第一个和第二个进行比较,将大的放在第二个位置,再将第二个和第
三比较,大的放在第三个位置,依次向后比较,比较n-1次,将最大的放在最后(n的位
置),然后再从第一个开始比较,比较n-2次,这次把最大的放到第n-1个位置,然后再
来回比较.遵循第i次遍历就从第一个数开始比较n-i次,将最后的值放在第n-i+1
的位置.
*/
public static void bubbleSort(int[] src) {
if (src.length > 0) {
int length = src.length;
for (int i = 1; i < length; i++) {
for (int j = 0; j < length - i; j++) {
if (src[j] > src[j + 1]) {
int temp = src[j];
src[j] = src[j + 1];
src[j + 1] = temp;
}
}
}
}
}
/**
* 插入排序:适用于少量数据的排序,时间复杂度O(n2),是稳定的排序算法,原地排序
* 将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序,
*/
public static void insertSort(int[] a) {
int length = a.length;
for (int i = 1; i < length; i++) {
int temp = a[i];
int j = i;
for (; j > 0 && a[j - 1] > temp; j--) {
a[j] = a[j - 1];
}
a[j] = temp;
}
}
/**
* 归并排序算法:稳定排序,非原地排序,空间复杂度O(n),时间复杂度O(nlogn)
* 将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的。
* 然后再把有序子序列合并为整体有序序列。
*/
public static void mergeSort(int a[], int low, int high) {
if (low < high) {
mergeSort(a, low, (low + high) / 2);
mergeSort(a, (low + high) / 2 + 1, high);
merge(a, low, (high + low) / 2, high);
}
}
/**
* 归并排序辅助方法,合并
*/
private static void merge(int[] a, int low, int mid, int high) {
int[] b = new int[high - low + 1];
int s = low;
int t = mid + 1;
int k = 0;
while (s <= mid && t <= high) {
if (a[s] <= a[t])
b[k++] = a[s++];
else
b[k++] = a[t++];
}
while (s <= mid)
b[k++] = a[s++];
while (t <= high)
b[k++] = a[t++];
for (int i = 0; i < b.length; i++) {
a[low + i] = b[i];
}
}
/**
* 选择排序:分为简单选择排序、树形选择排序(锦标赛排序)、堆排序 此算法为简单选择排序
* 每一趟从待排序的数据元素中选出最小(或最大)的一个元素,顺序放在已排好序的数列的最后,
* 直到全部待排序的数据元素排完。 选择排序是不稳定的排序方法。
*/
public static void selectSort(int[] a) {
int length = a.length;
for (int i = 0; i < length; i++) {
int minIndex = i;
for (int j = i + 1; j < a.length; j++) {
if (a[j] < a[minIndex]) {
minIndex = j;
}
}
if (minIndex != i) {
int temp = a[minIndex];
a[minIndex] = a[i];
a[i] = temp;
}
}
}
/**
* 希尔排序:先取一个小于n的整数d1作为第一个增量,把文件的全部记录分成(n除以d1)个组。
* 所有距离为d1的倍数的记录放在同一个组中。先在各组内进行直接插入排序;然后,
* 取第二个增量d2<d1重复上述的分组和排序,
* 直至所取的增量dt=1(dt<dt-l<…<d2<d1),
* 即所有记录放在同一组中进行直接插入排序为止。
*/
public static void shellSort(int[] a) {
int temp;
for (int k = a.length / 2; k > 0; k /= 2) {
for (int i = k; i < a.length; i++) {
for (int j = i; j >= k; j -= k) {
if (a[j - k] > a[j]) {
temp = a[j - k];
a[j - k] = a[j];
a[j] = temp;
}
}
}
}
}
/**
* 堆排序:最坏时间复杂度O(nlog2n),平均性能接近于最坏性能。由于建初始堆
所需的比较次数多,故堆不适合记录较少的比较 堆排序为原地不稳定排序
*/
public static void heapSort(int[] array) {
for (int i = 1; i < array.length; i++) {
makeHeap(array, i);
}
for (int i = array.length - 1; i > 0; i--) {
int temp = array[i];
array[i] = array[0];
array[0] = temp;
rebuildHeap(array, i);
}
}
/**
* 堆排序辅助方法---创建堆
*/
private static void makeHeap(int[] array, int k) {
int current = k;
while (current > 0 && array[current] > array[(current - 1)
- 6 - 2]) {
int temp = array[current];
array[current] = array[(current - 1) / 2];
array[(current - 1) / 2] = temp;
current = (current - 1) / 2;
}
}
/**
* 堆排序辅助方法---堆的根元素已删除,末尾元素已移到根位置,开始重建
*/
private static void rebuildHeap(int[] array, int size) {
int currentIndex = 0;
int right = currentIndex * 2 + 2;
int left = currentIndex * 2 + 1;
int maxIndex = currentIndex;
boolean isHeap = false;
while (!isHeap) {
if (left < size && array[currentIndex] < array[left]) {
maxIndex = left;
}
if (right < size && array[maxIndex] < array[right]) {
maxIndex = right;
}
if (currentIndex == maxIndex) {
isHeap = true;
} else {
int temp = array[currentIndex];
array[currentIndex] = array[maxIndex];
array[maxIndex] = temp;
currentIndex = maxIndex;
right = currentIndex * 2 + 2;
left = currentIndex * 2 + 1;
}
}
}
public static void main(String[] args) {
int data[] = { 2,8,-2,10,0,6,4};
//快速排序
Sort.displayData(data) ;
Sort.quickSort(data,0,data.length-1) ;
Sort.displayData(data) ;
/* //2.冒泡排序
Sort.displayData(data);
Sort.bubbleSort(data);
Sort.displayData(data); */
}
}
分享到:
相关推荐
算法课的一个小项目,语言python。代码实习7种排序算法,TK实现简单GUI,源码可以学习7中排序算法详细实现,和GUI的搭建,基本包含了常用GUI组件。
7种排序算法程序汇总 冒泡排序 选择排序 插入排序 希排序尔 快速排序 二叉排序树 堆排序
主要实现7种排序算法(直接插入排序、堆排序、基数排序、冒泡排序、归并排序、希尔排序、快速排序),能计算每种排序算法的运行时间,进行多次排序后,可以对各种排序算法时间复杂度进行直线拟合,并以图线的形式...
这个压缩包文件"7种排序算法可视化(matlab版本).rar"包含了一个MATLAB实现的项目,它提供了对七种常见排序算法的可视化展示。这些算法包括选择排序、快速排序、希尔排序、归并排序、插入排序、冒泡排序以及猴子...
主要在VC6.0上用MFC完成的排序算法和搜索算法: 首先弹出一个对话框,上面有排序前和排序后的编辑框,在排序前编辑框中输入整型数组,然后选择排序的方法,点排序按钮即将排序好的数组呈现在排序后的编辑框中。 排序...
本文将深入探讨七种经典排序算法,包括它们的工作原理、代码实现、性能测试以及适用场景。** 1. **冒泡排序(Bubble Sort)** 冒泡排序是最基础的排序算法之一,通过不断交换相邻的逆序元素来逐步排序。它的时间...
实验7: 内部排序算法比较.doc 实验7: 内部排序算法比较.doc 实验7: 内部排序算法比较.doc
### 十种排序算法介绍 #### 一、概述 本文旨在详细介绍十种常见的排序算法,这些算法不仅是计算机科学的基础组成部分,也是数据结构课程中的重要内容。排序算法被广泛应用于各种场景,如数据库管理、搜索引擎结果...
以下是这7种经典排序算法的详细介绍: 1. 冒泡排序(Bubble Sort):是最基础的排序方法,通过不断交换相邻的逆序元素来逐步排序。时间复杂度为O(n^2)。 2. 插入排序(Insertion Sort):将未排序的元素逐个插入到...
我们可以看到八种内部排序算法的性能存在一定的差异,快速排序、希尔排序、堆排序和归并排序等高效的排序算法在大多数情况下都能提供较好的性能,而直接插入排序、冒泡排序和选择排序等简单的排序算法则在大多数情况...
7.二叉树排序算法 二叉树排序算法是一种高效的排序算法,它的工作原理是通过将数组转换成二叉树,然后将二叉树的节点排序,以达到排序的目的。二叉树排序算法的时间复杂度为O(n log n),因此它适合大规模的数据排序...
插入排序、快速排序、希尔排序、基数排序、堆排序、选择排序、冒泡排序、归并排序 八种排序算法的实现与时间比较
本文将详细介绍七种基本排序算法,包括插入排序、快速排序、希尔排序、归并排序、选择排序、冒泡排序(以及双向冒泡排序)和堆排序,这些都是用C语言实现的。对于初学者来说,理解和掌握这些算法有助于提升编程技能...
该程序包含7大排序算法: # sort.bubbleSort() #冒泡排序 # sort.shellSort() #希尔排序 # sort.insertionSort() #插入排序 # sort.Selectionsort1() #选择排序 # sort.heapSort() #堆排序 # sort.countSort() ...
1) 对以下6种常用的内部排序算法进行比较:起泡排序,直接插入排序,简单选择排序,快速排序,希尔排序,堆排序。 2) 待排序记录的文件个数不小于1000( 其数据用伪随机数产生),至少用5组不同的输入数据作比较;比较...
在这个C++实现的项目中,我们有三种经典的排序算法被可视化:冒泡排序、插入排序和选择排序。这些算法的可视化能够帮助我们更好地理解它们的工作原理。** ### 冒泡排序 冒泡排序是最基础的排序算法之一,它通过重复...
本项目旨在实现并比较六种经典的排序算法——直接插入排序、折半插入排序、起泡排序、简单选择排序、堆排序以及2-路归并排序,使用C语言编程。为了全面评估这些算法,我们将在一组随机生成的30000个整数上运行它们,...
这篇实验报告主要关注了五种不同的排序算法:冒泡排序、插入排序、选择排序、归并排序和快速排序。在报告中,作者通过C++编程实现了这些算法,并进行了实际的性能比较,特别是在处理不同规模(N=1000, 10000, 100000...
这里我们将深入探讨七种常用的排序算法,并通过C++语言实现它们。这七种算法分别是:冒泡排序、选择排序、直接插入排序、希尔排序、堆排序、归并排序和快速排序。 1. **冒泡排序**: 冒泡排序是最基础的排序算法之...