做ppt介绍网站吗,哪里有培训网,虚拟主机和网站的关系,凡科网制作网站教程JAVA四种基本排序,包括冒泡法,插入法,选择法,SHELL排序法.其中选择法是冒泡法的改进,SHELL排序法是 插入法的改进.所以从根本上来说可以归纳为两种不同的排序方法:即:插入法#xff06;冒泡法一 插入法:遍历排序集合#xff0c;每到一个元素时#xff0c;都要将这个元素与所…JAVA四种基本排序,包括冒泡法,插入法,选择法,SHELL排序法.其中选择法是冒泡法的改进,SHELL排序法是 插入法的改进.所以从根本上来说可以归纳为两种不同的排序方法:即:插入法冒泡法 一 插入法:遍历排序集合每到一个元素时都要将这个元素与所有它之前的元素遍历比较一遍让符合排序顺序的元素挨个移动到当前范围内它最应该出现的位置。交换是相邻遍历移动双重循环控制实现.这种排序法属于地头蛇类型,在我的地牌上我要把所有的东西按一定的顺序规整,过来一个,规整一个. 处理代码如下: public void sort(int[] data) { int temp; for(int i1; i〈data.length; i){ for(int ji; (j〉0)(data[j]〉data[j-1]); j--){ tempdate[j]; data[j]data[j-1]; data[j-1]temp; } } } 二冒泡法:比较容易它的内层循环保证遍历一次后集合中最小大元素出现在它的正确位置下一次就是次小元素。。。该方法在集合分布的各种情况下交换移动的次数基本不变属于最慢的一种排序。实现也是双重循环控制。这种排序法属于过江龙,就是要找到极端,但是过奖龙也有大哥,二哥等,所以他们只能是大哥挑了二哥挑. 处理代码如下: public static int [] maopao(int[] data) { int temp; for(int i0; i〈data.length-1; i){ for(int ji1; j〈data.length; j){ if(data[i]〈data[j]){ tempdata[i]; data[i]data[j]; data[j]temp; } } } return data; 三选择法:该方法只是通过遍历集合记录最小大元素的位置一次遍历完后再进行交换位置操作类似冒泡但在比较过程中不进行交换操作只记录元素位置。一次遍历只进行一次交换操作。这个对与交换次序比较费时的元素比较适合。这种排序法比冒泡法要城府要深的多,我先记住极端数据,待遍历数据完了之后,我再处理,不像冒泡法那样只要比自己极端一点的就要处理,选择法只处理本身范围内的最极端数据. public static void xuanze(int[] data) { int temp; for (int i 0; i 〈 data.length; i) { int lowIndex i; for (int j data.length - 1; j 〉 i; j--) { if (data[j] 〉 data[lowIndex]) { lowIndex j; } } tempdata[i]; data[i]data[lowIndex]; data[lowIndex]temp; } } 四 Shell排序 它是对插入排序的一种改进是考虑将集合元素按照一定的基数划分成组去排序让每一组在局部范围内先排成基本有序最后在进行一次所有元素的插入排序。 public void sort(int[] data) { for(int idata.length/2; i〉2; i/2){ for(int j0; j〈i; j){ insertSort(data,j,i); } } insertSort(data,0,1); } private void insertSort(int[] data, int start, int inc) { int temp; for(int istartinc; i〈data.length; iinc){ for(int ji; (j〉inc)(data[j]〈data[j-inc]); j-inc){ tempdata[j]; data[j]data[j-inc] data[j-inc]temp; } } }转载于:https://www.cnblogs.com/jadmin/archive/2007/05/22/2206422.html