国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

2個(gè)java希爾排序示例

2019-11-26 15:30:12
字體:
供稿:網(wǎng)友

java希爾排序

希爾排序是插入排序的一種類型,也可以用一個(gè)形象的叫法縮小增量法。基本思想就是把一個(gè)數(shù)組分為好幾個(gè)數(shù)組,有點(diǎn)像分治法,不過這里的劃分是用一個(gè)常量d來控制。

這個(gè)0<d<n,n為數(shù)組的長(zhǎng)度。這個(gè)算法有了插入排序的速度,也可以算是一個(gè)改進(jìn)算法,在插入算法中,如果有一個(gè)最小的數(shù)在數(shù)組的最后面,用插入算法就會(huì)重最后一個(gè)

位置移動(dòng)到第一個(gè),這樣就會(huì)浪費(fèi)很大,使用這個(gè)改進(jìn)的希爾排序可以實(shí)現(xiàn)數(shù)據(jù)元素的大跨度的移動(dòng)。也就是這個(gè)算法的優(yōu)越之處。

復(fù)制代碼 代碼如下:

package cn.cqu.coce.xutao;

public class shell3 {
 public static void main(String args[]){
  int a[]={7,43,23,5,3,2,0,6,74,9};
  int n=a.length;
  for(int i=0;i<n;i++)
   System.out.print(a[i]+"/t");
  System.out.println();
     for(int gap=n/2;gap>0;gap/=2){
      for(int i=gap;i<n;i++){
       for(int j=i-gap;j>=0&&a[j]>a[j+gap];j-=gap){
        int temp=a[j+gap];
        a[j+gap]=a[j];
        a[j]=temp;
       }
      }
     }
  for(int i=0;i<n;i++)
   System.out.print(a[i]+"/t");
  System.out.println();
 }
}



第二個(gè)示例

復(fù)制代碼 代碼如下:

class Shell
{
    public void shell_sort(int [] arrays){
        for(int d=5;d>0;d=d-2){
            for(int c=0;c<arrays.length-d;c++){
                for(int i=c;i<arrays.length;i=i+d){
                    for(int j=i;j>0;j=j-d){
                        if(j<d)
                            break;
                        if(arrays[j]<arrays[j-d]){
                            int tmp;
                            tmp=arrays[j];
                            arrays[j]=arrays[j-d];
                            arrays[j-d]=tmp;

                        }
                    }
                }

            }
            snp(arrays);
        }

    }
    public void snp(int[] arrays){
        for(int i=0;i<arrays.length;i++){
            System.out.print(arrays[i]+" ");

        }
        System.out.println();
    }
    public static void main(String[] args)
    {
        Shell s=new Shell();
        int[] a={45,20,80,40,26,58,66,70};
        s.shell_sort(a);

    }
}

運(yùn)行結(jié)果:

復(fù)制代碼 代碼如下:

---------- java ----------
20 70 40 26 58 66 80
20 58 45 26 70 66 80
26 40 45 58 66 70 80

輸出完成 (耗時(shí) 0 秒) - 正常終止

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 安宁市| 章丘市| 威海市| 义马市| 丹江口市| 锦屏县| 阜新| 浑源县| 探索| 郁南县| 瓮安县| 六安市| 阳山县| 揭东县| 贺兰县| 安丘市| 雅安市| 白银市| 嘉善县| 年辖:市辖区| 东方市| 新疆| 连南| 凤山市| 游戏| 军事| 东城区| 田东县| 通山县| 合山市| 正宁县| 宜都市| 苏尼特左旗| 荥阳市| 定州市| 建始县| 安溪县| 准格尔旗| 万年县| 名山县| 宿州市|