日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢(xún)客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

用希爾排序法對(duì)一組數(shù)據(jù)由小到大進(jìn)行排序,數(shù)據(jù)分別為 69、56、12、136、3、55、46、 99、88、25。

例子:

(1)自定義函數(shù) shsort(),實(shí)現(xiàn)希爾排序。

(2) main() 函數(shù)作為程序的入口函數(shù)。程序代碼如下:

#include

int shsort(int s[], int n) /* 自定義函數(shù) shsort()*/

{

int i,j,d;

d=n/2; /*確定固定增雖值*/

while(d>=1)

{

for(i=d+1;i

{

s[0]=s[i]; /*設(shè)置監(jiān)視哨*/

j=i-d; /*確定要進(jìn)行比較的元素的最右邊位置*/

while((j>0)&&(s[0]

{

s[j+d]=s[j]; /*數(shù)據(jù)右移*/

j=j-d; /*向左移d個(gè)位置V*/

}

s[j + d]=s[0]; /*在確定的位罝插入s[i]*/

}

d = d/2; /*增里變?yōu)樵瓉?lái)的一半*/

}

return 0;

}

int main()

{

int a[11],i; /*定義數(shù)組及變量為基本整型*/

printf("請(qǐng)輸入 10 個(gè)數(shù)據(jù):n");

for(i=1;i

scanf("%d",&a[i]); /*從鍵盤(pán)中輸入10個(gè)數(shù)據(jù)*/

shsort(a, 10); /* 調(diào)用 shsort()函數(shù)*/

printf("排序后的順序是:n");

for(i=1;i

printf("%5d",a[i]); /*輸出排序后的數(shù)組*/

printf("n");

return 0;

}

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

69 56 12 136 3 55 46 99 88 25

排序后的順序是:

3 12 25 46 55 56 69 88 99 136

總結(jié):

希爾排序是在直接插入排序的基礎(chǔ)上做的改進(jìn),也就是將寒排序的序列按固定增量分成若干組,等距者在同二組中,然后再在組內(nèi)進(jìn)行直接插入排序。這里面的固定增量從 n/2 開(kāi)始,以后每次縮小到原來(lái)的一半。

分享到:
標(biāo)簽:希爾 排序
用戶(hù)無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定