码迷,mamicode.com
首页 > 编程语言 > 详细

AJPFX分享java排序之希尔排序

时间:2019-05-22 15:25:39      阅读:132      评论:0      收藏:0      [点我收藏+]

标签:算法   i++   ==   java   希尔   元素   shel   for   bsp   

(1)基本思想:算法先将要排序的一组数按某个增量d(n/2,n为要排序数的个数)分成若干组,每组中记录的下标相差d.对每组中全部元素进行直接插入排序,然后再用一个较小的增量(d/2)对它进行分组,在每组中再进行直接插入排序。当增量减到1时,进行直接插入排序后,排序完成。
(2)用java实现
public class shellSort {  
public  shellSort(){      
      int a[]={1,54,6,3,78,34,12,45,56,100}; 
      double d1=a.length;
      int temp=0;     
      while(true){ 
          d1= Math.ceil(d1/2);
          int d=(int) d1;
          for(int x=0;x<d;x++){ 
              for(int i=x+d;i<a.length;i+=d){
                  int j=i-d;
                  temp=a;
                  for(;j>=0&&temp<a[j];j-=d){
                        a[j+d]=a[j];               
                   }
                  a[j+d]=temp;  
              }        
          }          
             if(d==1) 
             break; 
            }      
           for(int i=0;i<a.length;i++)   
          System.out.println(a);  
          }
  }

AJPFX分享java排序之希尔排序

标签:算法   i++   ==   java   希尔   元素   shel   for   bsp   

原文地址:https://www.cnblogs.com/AJPFX/p/10906018.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!