c語言插入排序及希爾排序詳解

目錄

前言:

插入排序:

希爾排序:


前言:

? ? 排序在我們生活中無處不在,比如學生成就排名,商品價格排名等等,所以排序在數據結構的學習中尤為重要,今天就為大家介紹兩個經典的排序算法:插入排序和希爾排序

插入排序:

思路圖:

思路:

從第二個元素開始和前面的元素依次比較,如果前面的元素比它大,則將該元素移到后一位,如果該元素比它小,則直接插入該元素后面。

代碼實現:

void InsertSort(int* a, int n)
{int i = 0;for (i = 0;i < n-1;i++){int end = i;int tmp = a[end + 1];while (end >= 0){if (a[end] > tmp){a[end + 1] = a[end];end--;}else{break;}}a[end + 1] = tmp;}
}

時間復雜度:

? ? ? ?最壞情況下為O(N*N),此時待排序列為逆序,或者說接近逆序
??最好情況下為O(N),此時待排序列為升序,或者說接近升序。
空間復雜度:O(1)

希爾排序:

? 其實希爾排序就是插入排序的進階版,可以說是希爾對插入排序進行了優化。

思路圖:

思路:

步驟一:預排序,使數組接近有序

步驟二:插入排序

先將每間隔gap個元素的數據分為一組,將每組分別進行插入排序,使其接近有序

gap逐漸減小,gap減為1時就是進行步驟二的插入排序。

代碼實現:

void ShellSort(int* a, int n)
{int gap = n;while(gap>1){gap = gap / 2;int i = 0;for (i = 0;i < n - gap; i++){int end = i;int tmp = a[end + gap];while (end >= 0){if (a[end] > tmp){a[end + gap] = a[end];end -= gap;}else{break;}}a[end + gap] = tmp;}}
}

紙上得來終覺淺,絕知此事要躬行。快去實踐一下吧。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/214950.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/214950.shtml
英文地址,請注明出處:http://en.pswp.cn/news/214950.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

adb 查找啟動的包名以及導出安裝包

查看安卓內包名 adb 查看所有安裝的包 adb shell pm list packages查看安裝的第三方app的包名 adb shell pm list packages -3查看啟動的app的包名 adb shell dumpsys activity top | find "ACTIVITY"adb shell dumpsys activity activities | findstr "Run…

深入解析C++中的虛函數和虛繼承:實現多態性與繼承關系的高級特性

這里寫目錄標題 虛函數虛函數實現動態綁定虛繼承抽象類 虛函數 虛函數是在C中用于實現多態性的一種特殊函數。它通過使用關鍵字"virtual"進行聲明&#xff0c;在基類中定義&#xff0c;可在派生類中進行重寫。虛函數允許在運行時根據對象的實際類型來調用相應的函數…

pip 通過git安裝庫

舉例&#xff1a;安裝peft庫 git clone https://github.com/huggingface/peft.git cd peft python -m pip install . 解釋&#xff1a; 使用git clone克隆PEFT庫的代碼。進入克隆的目錄。使用python -m pip install .來安裝PEFT庫。 補充&#xff1a;使用pip安裝到指定編譯器…

BigData之Google Hadoop中間件安裝

前言 Hadoop / Zookeeper / Hbase 因資源有限 這三個都是安裝在同一臺Centos7.9的機器上 但通過配置 所以在邏輯上是distributed模式 1 Java安裝 1.1 下載java11 tar/opt/java/jdk-11.0.5/ 1.2 環境配置修改 文件/etc/profile export JAVA_HOME/opt/java/jdk-11.0.5/ e…

新網站如何被搜索引擎迅速收錄

說到搜索引擎收錄新站的問題&#xff0c;大家應該對這個問題產生了一個共鳴&#xff0c;那就是要想要網站被收&#xff0c;難! 難于上青天。那是不是說這青天我們就上不了了呢&#xff0c;不是的&#xff0c;其實要想百度快速收錄新站&#xff0c;還是有訣竅的&#xff0c;關鍵…

【UE c++】 UE中c++如何使用回調(關卡動畫回調為例)

本文使用關卡動畫回調為例 1.創建關卡動畫 FString assetsPath "你的路徑"; FStringAssetReference sequenceName(assetsPath);ULevelSequence* sequenceAsset Cast<ULevelSequence>(sequenceName.TryLoad());ALevelSequenceActor* currentLevelSequenceAc…

HarmonyOS編譯開源native庫(OpenSSL實例)

前言 近期項目要開始做鴻蒙版本&#xff0c;有一部分依賴native的代碼也需要遷移&#xff0c;某個native模塊依賴openssl&#xff0c;需要在鴻蒙下重新編譯openssl才行。一開始找了很多相關文檔都沒有得到方法&#xff0c;無奈只能自己憑經驗慢慢試&#xff0c;最后還是成功了…

JS基礎之執行上下文

JS基礎之執行上下文 執行上下文順序執行可執行代碼執行上下文棧回顧上文 執行上下文 順序執行 寫個JavaScript的開發者都會有個直觀的印象&#xff0c;那就是順序執行&#xff1a; var foo function(){console.log(foo1) } foo(); //foo1 var foo function(){console.log(…

HTML面試題---專題一

文章目錄 一、前言二、 HTML5 中 <header> 和 <footer> 標簽的用途是什么&#xff1f;三、如何在 HTML 中嵌入 SVG&#xff08;可縮放矢量圖形&#xff09;文件&#xff1f;四、解釋 contenteditable 屬性的用途五、如何創建隨屏幕尺寸縮放的響應式圖像&#xff1f…

八大排序算法【上】

冒泡排序 冒泡排序是一種 穩定 的排序算法。 它的工作原理是每次檢查相鄰兩個元素&#xff0c;如果前面的元素與后面的元素滿足給定的排序條件&#xff0c;就將相鄰兩個元素交換。當沒有相鄰的元素需要交換時&#xff0c;排序就完成了。 假設我們想要從小到大進行排序&#…

大模型:常見的文字表情包(可以直接加到微調數據里)

大模型&#xff1a;常見的文字表情包(可以直接加到微調數據里) 返回論文目錄 返回資料目錄 表情符號含義&#x1f60a;愉快、微笑&#x1f602;大笑&#x1f60d;愛心眼&#x1f60e;酷、自信&#x1f914;思考、疑惑&#x1f61c;調皮、頑皮&#x1f64c;鼓掌、慶祝&#x1f…

線上扭蛋機小程序搭建,扭蛋與科技的完美結合

扭蛋機作為當下比較熱門的一種盲盒玩法&#xff0c;在年輕人群體中非常受歡迎。隨著經濟的增長和人們生活水平的提高&#xff0c;人們對娛樂消費需求也在增加&#xff0c;扭蛋機的受眾群體也在擴大。 目前線上扭蛋機小程序也獲得了大眾的青睞&#xff0c;扭蛋機小程序就是把線…

記錄一下快速上手Springboot登錄注冊項目

本教程需要安裝以下工具&#xff0c;如果不清楚怎么安裝的可以看下我的這篇文章 鏈接: https://blog.csdn.net/qq_30627241/article/details/134804675 管理工具&#xff1a; maven IDE&#xff1a; IDEA 數據庫&#xff1a; MySQL 測試工具&#xff1a; Postman 打開IDE…

Ansys結構靜力學仿真的一般流程

1. 模型實體 三維幾何模型的構建。 2. 材料屬性 根據實際情況&#xff0c;為模型中的各個部分定義材料屬性&#xff0c;包括彈性模量、泊松比、密度等。 3. 單元類型 node 結點數等 4. 網格劃分 網格屬性&#xff08;尺寸&#xff09; 5. 邊界條件 這個定義有點模糊&#x…

AR-LDM原理及代碼分析

AR-LDM原理AR-LDM代碼分析pytorch_lightning(pl)的hook流程main.py 具體分析TrainSampleLightningDatasetARLDM blip mm encoder AR-LDM原理 左邊是模仿了自回歸地從1, 2, ..., j-1來構造 j 時刻的 frame 的過程。 在普通Stable Diffusion的基礎上&#xff0c;使用了1, 2, .…

天池SQL訓練營(六)-綜合練習題-10道經典題目

如果你還沒有學習過SQL訓練營的以下知識&#xff0c;請查閱主頁博文學習&#xff1a; Task 1 SQL基礎&#xff1a;初識數據庫與SQL-安裝與基本介紹等 Task 2 SQL基礎&#xff1a;查詢與排序-select、運算符、聚合分組查詢等 Task 3 SQL進階&#xff1a;復雜查詢方法-視圖、子查…

網工內推 | 項目經理專場,最高20K*13薪,軟考證書優先

01 Trasen 招聘崗位&#xff1a;大項目經理&#xff08;醫療行業/HIS&#xff09; 職責描述&#xff1a; 1.負責項目按計劃完成交付并順利驗收結項&#xff1b; 2.參與項目前期預算、評審、方案設計等&#xff1b; 3.負責具體項目實施&#xff0c;制定項目計劃、組織項目資源、…

Web網站服務(二)

1、客戶機地址限制。 Require all granted&#xff1a;表示允許所有主機訪問。 Require all denied&#xff1a;表示拒絕所有主機訪問。 Require local&#xff1a;表示僅允許本地主機訪問。 Require [not] host <主機名或域名列表>&#xff1a;表示允許或拒絕指定主機或…

Web安全-SQL注入【sqli靶場第11-14關】(三)

★★實戰前置聲明★★ 文章中涉及的程序(方法)可能帶有攻擊性&#xff0c;僅供安全研究與學習之用&#xff0c;讀者將其信息做其他用途&#xff0c;由用戶承擔全部法律及連帶責任&#xff0c;文章作者不承擔任何法律及連帶責任。 0、總體思路 先確認是否可以SQL注入&#xff0…