写了一个插入排序,接着写希尔排序,分组之后的希尔排序就是进行好几次插入排序,这样子不是更费力了吗,数据结构与算法的一些简单的疑惑
3条回答 默认 最新
- CSDN专家-赖老师(软件之家) 2021-07-23 15:41关注
希尔排序不是插入排序哦,发个希尔排序的算法给你参考一下。
package T5; public class ShellSort { int a[]; public ShellSort() { a = new int[]{8,19,2,3,100,99,1000,888,-1,0}; /* * 第一次是d=5组 * (8,99),(19,1000),(2,888),(3,-1),(100,0) * 交换 * (8,99),(19,1000),(2,888),(-1,3),(0,100) * 8,19,2,-1,0,99,1000,888,3,100 * 第二次是d=2组 * (8,2,0,1000,3),(19,-1,99,888,100) * 交换 * (0,2,3,8,1000),(-1,19,99,100,888) * 0,-1,2,19,3,99,8,100,1000,888 * 第3次是d=1时,其实只有一组,就是直接插入排序 * * * */ } public ShellSort(int a[]) { this.a = a; } public void shellSort(){ int n = a.length; /*分组排序:分组的规则 * 1.d = 数组长度/2; * 2.d = d/2; * */ for(int d=n/2;d>0;d/=2){ // System.out.println("d="+d+"时的排序情况"); //插入排序 for(int i=0;i<d;i++){ //增量为1时排序结束 //遍历所有子序 // System.out.print(i+"\t"); for(int j=i+d;j<n;j+=d){ // System.out.print(j+"\t"); //对每个子序进行插入排序 int insertNode = a[j]; int k=j-d; while(k>=i&& a[k]>insertNode){ a[k+d]=a[k]; k=k-d; // print(); } a[k+d]=insertNode; // print(); } // System.out.println("--------------------"); } // print(); } print(); } public void print(){ for (int e : a) { System.out.print(e+"\t"); } System.out.println(""); } public static void main(String[] args) { ShellSort shellSort = new ShellSort(); System.out.println("排序前"); shellSort.print(); shellSort.shellSort(); // shellSort.print(); } }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 delta降尺度计算的一些细节,有偿
- ¥15 Arduino红外遥控代码有问题
- ¥15 数值计算离散正交多项式
- ¥30 数值计算均差系数编程
- ¥15 redis-full-check比较 两个集群的数据出错
- ¥15 Matlab编程问题
- ¥15 训练的多模态特征融合模型准确度很低怎么办
- ¥15 kylin启动报错log4j类冲突
- ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大
- ¥15 import arcpy出现importing _arcgisscripting 找不到相关程序