霽彩華年,因夢同行—— 慶祝深圳霽因生物醫(yī)藥轉(zhuǎn)化研究院成立十周年 情緒益生菌PS128助力孤獨癥治療,權(quán)威研究顯示可顯著改善孤獨癥癥狀 PARP抑制劑氟唑帕利助力患者從維持治療中獲益,改寫晚期卵巢癌治療格局 新東方智慧教育發(fā)布“東方創(chuàng)科人工智能開發(fā)板2.0” 精準血型 守護生命 腸道超聲可用于檢測兒童炎癥性腸病 迷走神經(jīng)刺激對抑郁癥有積極治療作用 探索梅尼埃病中 MRI 描述符的性能和最佳組合 自閉癥患者中癡呆癥的患病率增加 超聲波 3D 打印輔助神經(jīng)源性膀胱的骶神經(jīng)調(diào)節(jié) 胃食管反流病患者耳鳴風險增加 間質(zhì)性膀胱炎和膀胱疼痛綜合征的臨床表現(xiàn)不同 研究表明 多語言能力可提高自閉癥兒童的認知能力 科學家揭示人類與小鼠在主要癌癥免疫治療靶點上的驚人差異 利用正確的成像標準改善對腦癌結(jié)果的預測 地中海飲食通過腸道細菌變化改善記憶力 讓你在 2025 年更健康的 7 種驚人方法 為什么有些人的頭發(fā)和指甲比其他人長得快 物質(zhì)的使用會改變大腦的結(jié)構(gòu)嗎 飲酒如何影響你的健康 20個月,3大平臺,300倍!元育生物以全左旋蝦青素引領(lǐng)合成生物新紀元 從技術(shù)困局到創(chuàng)新錨點,天與帶來了一場屬于養(yǎng)老的“情緒共振” “華潤系”大動作落槌!昆藥集團完成收購華潤圣火 十七載“冬至滋補節(jié)”,東阿阿膠將品牌營銷推向新高峰 150個國家承認巴勒斯坦國意味著什么 中國海警對非法闖仁愛礁海域菲船只采取管制措施 國家四級救災應急響應啟動 涉及福建、廣東 女生查分查出608分后,上演取得理想成績“三件套” 多吃紅色的櫻桃能補鐵、補血? 中國代表三次回擊美方攻擊指責 探索精神健康前沿|情緒益生菌PS128閃耀寧波醫(yī)學盛會,彰顯科研實力 圣美生物:以科技之光,引領(lǐng)肺癌早篩早診新時代 神經(jīng)干細胞移植有望治療慢性脊髓損傷 一種簡單的血漿生物標志物可以預測患有肥胖癥青少年的肝纖維化 嬰兒的心跳可能是他們說出第一句話的關(guān)鍵 研究發(fā)現(xiàn)基因檢測正成為主流 血液測試顯示心臟存在排斥風險 無需提供組織樣本 假體材料有助于減少靜脈導管感染 研究發(fā)現(xiàn)團隊運動對孩子的大腦有很大幫助 研究人員開發(fā)出診斷 治療心肌炎的決策途徑 兩項研究評估了醫(yī)療保健領(lǐng)域人工智能工具的發(fā)展 利用女子籃球隊探索足部生物力學 抑制前列腺癌細胞:雄激素受體可以改變前列腺的正常生長 肽抗原上的反應性半胱氨酸可能開啟新的癌癥免疫治療可能性 研究人員發(fā)現(xiàn)新基因療法可以緩解慢性疼痛 研究人員揭示 tisa-cel 療法治療復發(fā)或難治性 B 細胞淋巴瘤的風險 適量飲酒可降低高危人群罹患嚴重心血管疾病的風險 STIF科創(chuàng)節(jié)揭曉獎項,新東方智慧教育榮膺雙料殊榮 中科美菱發(fā)布2025年產(chǎn)品戰(zhàn)略布局!技術(shù)方向支撐產(chǎn)品生態(tài)縱深! 從雪域高原到用戶口碑 —— 復方塞隆膠囊的品質(zhì)之旅
您的位置:首頁 >綜合精選 >

鏈表插入排序(插入排序思路)

關(guān)于鏈表插入排序,插入排序思路這個問題很多朋友還不知道,今天小六來為大家解答以上的問題,現(xiàn)在讓我們一起來看看吧!

1、轉(zhuǎn)個過來插入排序(Insertion Sort)的基本思想是:每次將一個待排序的記錄,按其關(guān)鍵字大小插入到前面已經(jīng)排好序的子文件中的適當位置,直到全部記錄插入完成為止。

2、????  本節(jié)介紹兩種插入排序方法:直接插入排序和希爾排序。

3、 直接插入排序基本思想基本思想????  假設(shè)待排序的記錄存放在數(shù)組R[1..n]中。

4、初始時,R[1]自成1個有序區(qū),無序區(qū)為R[2..n]。

5、從i=2起直至i=n為止,依次將R[i]插入當前的有序區(qū)R[1..i-1]中,生成含n個記錄的有序區(qū)。

6、2、第i-1趟直接插入排序:????  通常將一個記錄R[i](i=2,3,…,n-1)插入到當前的有序區(qū),使得插入后仍保證該區(qū)間里的記錄是按關(guān)鍵字有序的操作稱第i-1趟直接插入排序。

7、????  排序過程的某一中間時刻,R被劃分成兩個子區(qū)間R[1..i-1](已排好序的有序區(qū))和R[i..n](當前未排序的部分,可稱無序區(qū))。

8、????  直接插入排序的基本操作是將當前無序區(qū)的第1個記錄R[i]插人到有序區(qū)R[1..i-1]中適當?shù)奈恢蒙?,使R[1..i]變?yōu)樾碌挠行騾^(qū)。

9、因為這種方法每次使有序區(qū)增加1個記錄,通常稱增量法。

10、????  插入排序與打撲克時整理手上的牌非常類似。

11、摸來的第1張牌無須整理,此后每次從桌上的牌(無序區(qū))中摸最上面的1張并插入左手的牌(有序區(qū))中正確的位置上。

12、為了找到這個正確的位置,須自左向右(或自右向左)將摸來的牌與左手中已有的牌逐一比較。

13、一趟直接插入排序方法1.簡單方法????  首先在當前有序區(qū)R[1..i-1]中查找R[i]的正確插入位置k(1≤k≤i-1);然后將R[k..i-1]中的記錄均后移一個位置,騰出k位置上的空間插入R[i]。

14、??注意:????  若R[i]的關(guān)鍵字大于等于R[1..i-1]中所有記錄的關(guān)鍵字,則R[i]就是插入原位置。

15、2.改進的方法  一種查找比較操作和記錄移動操作交替地進行的方法。

16、具體做法:????  將待插入記錄R[i]的關(guān)鍵字從右向左依次與有序區(qū)中記錄R[j](j=i-1,i-2,…,1)的關(guān)鍵字進行比較:???? ?、?若R[j]的關(guān)鍵字大于R[i]的關(guān)鍵字,則將R[j]后移一個位置;?????? ②若R[j]的關(guān)鍵字小于或等于R[i]的關(guān)鍵字,則查找過程結(jié)束,j+1即為R[i]的插入位置。

17、????  關(guān)鍵字比R[i]的關(guān)鍵字大的記錄均已后移,所以j+1的位置已經(jīng)騰空,只要將R[i]直接插入此位置即可完成一趟直接插入排序。

18、直接插入排序算法1.算法描述?? void lnsertSort(SeqList R)??? { //對順序表R中的記錄R[1..n]按遞增序進行插入排序???? int i,j;???? for(i=2;i<=n;i++) //依次插入R[2],…,R[n]?????? if(R[i].key

19、???   哨兵有兩個作用: ?、?進人查找(插入位置)循環(huán)之前,它保存了R[i]的副本,使不致于因記錄后移而丟失R[i]的內(nèi)容; ?、?它的主要作用是:在查找循環(huán)中"監(jiān)視"下標變量j是否越界。

20、一旦越界(即j=0),因為R[0].key和自己比較,循環(huán)判定條件不成立使得查找循環(huán)結(jié)束,從而避免了在該循環(huán)內(nèi)的每一次均要檢測j是否越界(即省略了循環(huán)判定條件"j>=1")。

21、??注意: ?? ① 實際上,一切為簡化邊界條件而引入的附加結(jié)點(元素)均可稱為哨兵。

22、  ?? 【例】單鏈表中的頭結(jié)點實際上是一個哨兵 ?、?引入哨兵后使得測試查找循環(huán)條件的時間大約減少了一半,所以對于記錄數(shù)較大的文件節(jié)約的時間就相當可觀。

23、對于類似于排序這樣使用頻率非常高的算法,要盡可能地減少其運行時間。

24、所以不能把上述算法中的哨兵視為雕蟲小技,而應該深刻理解并掌握這種技巧。

25、給定輸入實例的排序過程????  設(shè)待排序的文件有8個記錄,其關(guān)鍵字分別為:49,38,65,97,76,13,27,49。

26、為了區(qū)別兩個相同的關(guān)鍵字49,后一個49的下方加了一下劃線以示區(qū)別。

27、其排序過程見【動畫模擬演示】算法分析1.算法的時間性能分析 ????  對于具有n個記錄的文件,要進行n-1趟排序。

28、???? 各種狀態(tài)下的時間復雜度:┌─────────┬─────┬──────┬──────┐│ 初始文件狀態(tài)????? │??? 正序??? │????? 反序??? │無序(平均)?? │├─────────┼─────┼──────┼──────┤│ 第i趟的關(guān)鍵?????? │??? 1?????? │????? i+1???? │ (i-2)/2?? ││ 字比較次數(shù)??????? │?????????? │???????????? │???????????? │├─────────┼─────┼──────┼──────┤│總關(guān)鍵字比較次數(shù)?? │??? n-1???? │(n+2)(n-1)/2│ ≈n2/4????? │├─────────┼─────┼──────┼──────┤│第i趟記錄移動次數(shù) │??? 0?????? │ i+2???????? │ (i-2)/2?? │├─────────┼─────┼──────┼──────┤│總的記錄移動次數(shù)?? │??? 0?????? │(n-1)(n+4)/2│ ≈n2/4????? │├─────────┼─────┼──────┼──────┤│時間復雜度???????? │?? 0(n)?? │ O(n2)???? │ O(n2)???? │└─────────┴─────┴──────┴──────┘注意:????  初始文件按關(guān)鍵字遞增有序,簡稱"正序"。

29、 ???? 初始文件按關(guān)鍵字遞減有序,簡稱"反序"。

30、 2.算法的空間復雜度分析????  算法所需的輔助空間是一個監(jiān)視哨,輔助空間復雜度S(n)=O(1)。

31、是一個就地排序。

32、3.直接插入排序的穩(wěn)定性????  直接插入排序是穩(wěn)定的排序方法。

本文分享完畢,希望對大家有所幫助。

標簽:

免責聲明:本文由用戶上傳,與本網(wǎng)站立場無關(guān)。財經(jīng)信息僅供讀者參考,并不構(gòu)成投資建議。投資者據(jù)此操作,風險自擔。 如有侵權(quán)請聯(lián)系刪除!

最新文章