数组排序-冒泡排序-选择排序-插入排序-希尔排序-快速排序-Java实现
这五种排序算法难度依次增加。
冒泡排序:
第一次将数组相邻两个元素依次比较,然后将大的元素往后移,像冒泡一样,最终最大的元素被移到数组的最末尾。
第二次将数组的前n-1个元素取出,然后相邻两个元素依次比较,将大的元素往后移,最终n-1个元素中最大的元素又在末尾。
重复上面的步骤,直到数组只有1个元素为止。因为每次都将上一次比较剩下的最大元素放到末尾,所以当所有比较结束的时候,排序结束。
public void bubbleSort(T[] array)
{
for(int i = array.length-1;i>0; i--)
{
for(int j = 0; j <i; j++)
{
if(array[j].compareTo(array[j+1]) > 0)
{
T temp = array[j];
array[j] = array[j+1];
array[j+1] = temp;
}
}
}
}
二)选择排序
选择排序和冒泡排序类似,只是每次循环的时候将最大的元素位置记下来,然后当循环结束的时候,将最大的元素与最末尾元素进行调换。这样,当所有循环结束的时候,数组排序也结束。
@Override
public void selectionSort(T[] array)
{
for(int i = array.length-1; i>0; i--)
{
int max = 0;
for(int j = 0; j <= i; j++)
{
if(array[max].compareTo(array[j]) < 0)
{
max = j;
}
} T temp = array[max];
array[max] = array[i];
array[i] = temp;
}
}
三)插入排序
插入排序的思想是遍历整个数组,从第一个元素开始,在遍历过程中将该元素与之前元素比较,将它插入到之前元素的中间,要求是该元素大于前面所有元素,且小于等于后面所有元素。
@Override
public void insertionSort(T[] array)
{
this.insertionSort(array,0,array.length);
} @Override
public void insertionSort(T[] array, int start, int length)
{
for(int i = start; i < start+length;i++)
{
for(int j = start; j < i; j++)
{
if(array[i].compareTo(array[j]) < 0)
{
T temp = array[i];
for(int k = i; k > j; k--)
{
array[k] = array[k-1];
}
array[j] = temp;
}
}
}
}
四)希尔排序
希尔排序是插入排序的升级版。希尔排序会设置一个步长gap,然后不断减小gap,直到gap为1。而每次将数组中长度为gap的元素进行排序。其实就是先对数组进行局部排序,使得数组在总体上有序的,这样在插入排序的时候就不需要进行大规模的数据移动。
@Override
public void shellSort(T[] array)
{
int gap = array.length/2;
while(gap >=1)
{
for(int i = gap; i<array.length; i++)
{
this.insertionSort(array, i-gap, gap+1);
}
gap = gap/2;
}
}
五)快速排序
快速排序会使用到分治法和递归思想。每次排序的时候,选取一个元素,将所有小于它的元素放到左边,将所有大于它的元素放到它的右边。然后将左边和右边的元素分别看成一个数组,然后递归将剩余的元素按照之前的方式排序。当数组长度为1的时候,递归结束,整个数组排序也完成。
@Override
public void quickSort(T[] array)
{
this.quickSortInternal(array, 0, array.length-1);
} private void quickSortInternal(T[] array, int left, int right)
{
if(left >= right)
{
return;
} int _left = left;
int _right = right; boolean flag = false;
while(left!=right)
{
if(flag == false)
{
//从右向左逼近
if(array[right].compareTo(array[left]) < 0)
{
T temp = array[left];
array[left] = array[right];
array[right] = temp;
//交换后 应该调换方向
flag = !flag;
}
right--;
}
else
{
//从左向右逼近
if(array[left].compareTo(array[right]) > 0)
{
T temp = array[left];
array[left] = array[right];
array[right] = temp;
//交换后 应该调换方向
flag = !flag;
}
left++;
}
}
//递归
this.quickSortInternal(array, _left, left-1);
this.quickSortInternal(array, right+1, _right);
}
}
数组排序-冒泡排序-选择排序-插入排序-希尔排序-快速排序-Java实现的更多相关文章
- 学习C#之旅 冒泡排序,选择排序,插入排序,希尔排序[资料收集]
关于冒泡排序,选择排序,插入排序,希尔排序[资料收集] 以下资料来源与网络 冒泡排序:从后到前(或者从前到后)相邻的两个两两进行比较,不满足要求就位置进行交换,一轮下来选择出一个最小(或最大)的放到 ...
- 冒泡排序 & 选择排序 & 插入排序 & 希尔排序 JavaScript 实现
之前用 JavaScript 写过 快速排序 和 归并排序,本文聊聊四个基础排序算法.(本文默认排序结果都是从小到大) 冒泡排序 冒泡排序每次循环结束会将最大的元素 "冒泡" 到最 ...
- 冒泡排序 选择排序 插入排序希尔排序 java
双向冒泡 package com.huang; public class _014_bubb_sort { int[] b={1,2}; static int a[]={12,4,35,65,43,6 ...
- 内部排序->插入排序->希尔排序
文字描述 希尔排序又称缩小增量排序,也属于插入排序类,但在时间效率上较之前的插入排序有较大的改进. 从之前的直接插入排序的分析得知,时间复杂度为n*n, 有如下两个特点: (1)如果待排序记录本身就是 ...
- 插入排序、冒泡排序、选择排序、希尔排序、高速排序、归并排序、堆排序和LST基数排序——C++实现
首先是算法实现文件Sort.h.代码例如以下: <pre name="code" class="java">/* * 实现了八个经常使用的排序算法: ...
- 数据结构和算法(Golang实现)(22)排序算法-希尔排序
希尔排序 1959 年一个叫Donald L. Shell (March 1, 1924 – November 2, 2015)的美国人在Communications of the ACM 国际计算机 ...
- 排序算法--希尔排序(Shell Sort)_C#程序实现
排序算法--希尔排序(Shell Sort)_C#程序实现 排序(Sort)是计算机程序设计中的一种重要操作,也是日常生活中经常遇到的问题.例如,字典中的单词是以字母的顺序排列,否则,使用起来非常困难 ...
- 《Algorithm算法》笔记:元素排序(2)——希尔排序
<Algorithm算法>笔记:元素排序(2)——希尔排序 Algorithm算法笔记元素排序2希尔排序 希尔排序思想 为什么是插入排序 h的确定方法 希尔排序的特点 代码 有关排序的介绍 ...
- C数据结构排序算法——希尔排序法用法总结(转http://www.cnblogs.com/skywang12345/p/3597597.html)
希尔排序介绍 希尔排序(Shell Sort)是插入排序的一种,它是针对直接插入排序算法的改进.该方法又称缩小增量排序,因DL.Shell于1959年提出而得名. 希尔排序实质上是一种分组插入方法.它 ...
随机推荐
- 利用递归生成组合数C(n,m)
/*===================================== 数的组合问题.从1,2,…,n中取出m个数,将所有组合按照字典顺序列出. 如n=3,m=2时,输出: 1 2 1 3 2 ...
- Linux- Bond
---------------check NIC----------------- ①mii-tool 命令 ②ethtool 命令 -i 参数,显示网卡的驱动信息, -S 参数,底层工作状态信息③d ...
- 取消GridView/ListView item被点击时的效果
方法一,在控件被初始化的时候设置 ? 1 2 gridView.setSelector(new ColorDrawable(Color.TRANSPARENT)); listView.setSelec ...
- 数据接口管理工具 thx RAP
RAP是数据接口管理工具.在开发时前端将请求转至RAP,由RAP提供模拟数据:而后端使用RAP测试接口的正确性.这样RAP就成为了开发过程中的强 依赖,进而确保接口文档的实时正确性.RAP采用JSON ...
- R(三): R包原理及安装
包(package)是多个函数的集合,常作为分享代码的基本单元,代码封装成包可以方便其他用户使用.越来越多的R包正在由世界上不同的人所创建并分发,这些分发的R包,可以从CRAN 或 github 上获 ...
- 用HTML5构建一个流程图绘制工具
在我们的开发工程中经常会使用到各种图,所谓的图就是由节点和节点之间的连接所形成的系统,数学上专门有一个分支叫图论(Graph Theroy).利用图我们可以做很多工具,比如思维导图,流程图,状态机,组 ...
- Ext JS4 学习笔记之发送表单(Form)时也将表单下的表格(Grid)数据一同发送的方法
Ext JS4 学习笔记之发送表单(Form)时也将表单下的表格(Grid)数据一同发送的方法 昨天在开发的时候遇到个小问题,就是如何将Grid的内容与Form一起发送到服务器端.默认情况下,表单(F ...
- RSA加密工具包
主要参考: http://www.blogjava.net/icewee/archive/2012/05/19/378570.html http://snowolf.iteye.com/ 基于以上代码 ...
- [转]String.getBytes()和new String()
在Java中,String.getBytes(String decode)方法会根据指定的decode编码返回某字符串在该编码下的byte数组表示,如 byte[] b_gbk = "中&q ...
- 06socket编程
socket可以看成是用户进程与内核网络协议栈的编程接口. socket不仅可以用于本机的进程间通信,还可以用于网络上不同主机的进程间通信. IPv4套接口地址结构通常也称为“网际套接字地址结构”,它 ...