插入排序(Insertion sort)是一種簡單直觀且穩定的排序算法。
<br>
如果有一個已經有序的數據序列,要求在這個已經排好的數據序列中插入一個數,但要求插入后此數據序列仍然有序,這個時候就要用到一種新的排序方法——插入排序法,插入排序的基本操作就是將一個數據插入到已經排好序的有序數據中,從而得到一個新的、個數加一的有序數據,算法適用于少量數據的排序,時間復雜度為O(n^2)。是穩定的排序方法。
<br>
插入算法把要排序的數組分成兩部分:第一部分包含了這個數組的所有元素,但將最后一個元素除外(讓數組多一個空間才有插入的位置),而第二部分就只包含這一個元素(即待插入元素)。在第一部分排序完成后,再將這個最后元素插入到已排好序的第一部分中。
<br>
插入排序的基本思想是:每步將一個待排序的記錄,按其關鍵碼值的大小插入前面已經排序的文件中適當位置上,直到全部插入完為止。
<br>
### 原理:
現有一組數組 arr = [5, 6, 3, 1, 8, 7, 2, 4]
```
[5] 6 3 1 8 7 2 4
↑ │
└───┘
[5, 6] 3 1 8 7 2 4
↑ │
└────────┘
[3, 5, 6] 1 8 7 2 4
↑ │
└──────────┘
[1, 3, 5, 6] 8 7 2 4
↑ │
└──┘
[1, 3, 5, 6, 8] 7 2 4
↑ │
└────┘
[1, 3, 5, 6, 7, 8] 2 4
↑ │
└────────────────┘
[1, 2, 3, 5, 6, 7, 8] 4
↑ │
└─────────────┘
[1, 2, 3, 4, 5, 6, 7, 8]
```
```
function insertSort($arr){
for($i=1; $i<count($arr); $i++){
$tmp = $arr[$i];
$key = $i-1;
while($key >= 0 && $tmp < $arr[$key]){
$arr[$key+1] = $arr[$key];
$key--;
}
if (($key+1)!=$i) {
$arr[$key+1]=$tmp;
}
}
return $arr;
}
```
- 概述說明
- 數據結構
- 數組
- 棧
- 隊列
- 鏈表
- 樹
- 堆
- 圖
- 常用算法
- 排序算法
- 選擇排序
- 冒泡排序
- 插入排序
- 快速排序
- 歸并排序
- 希爾排序
- 堆排序
- 計數排序
- 基數排序
- 二分查找
- 貪心算法
- 回溯算法
- 剪枝算法
- 分支限界法
- 動態規劃
- 設計模式
- 工廠模式
- 抽象工廠模式
- 單例模式
- 建造者模式
- 原型模式
- 適配器模式
- 橋接模式
- 過濾器模式
- 組合模式
- 裝飾器模式
- 外觀模式
- 享元模式
- 代理模式
- 責任鏈模式
- 命令模式
- 解釋器模式
- 迭代器模式
- 中介者模式
- 備忘錄模式
- 觀察者模式
- 狀態模式
- 空對象模式
- 策略模式
- 模板模式
- 訪問者模式
- 并發
- 多線程
- 線程安全
- 一致性、事務
- 鎖
- 操作系統
- 計算機原理
- CPU
- 進程
- 線程
- 協程
- Linux
- 運維
- 常規監控
- 統計分析
- 自動化運維
- 測試
- 文檔管理
- 日志管理
- 中間件
- Web Server
- Nginx
- Apache
- Tomcat
- 緩存
- 消息隊列
- 網絡協議
- 協議
- OSI 七層協議
- TCP/IP
- HTTP
- HTTP2.0
- HTTPS
- 網絡模型
- Epoll
- kqueue
- 數據庫
- 基礎理論
- MySQL
- NoSQL
- 搜索引擎
- Elasticsearch
- sphinx
- Lucene
- 性能
- 性能優化方法論
- 容量評估
- CDN 網絡
- 連接池
- 性能調優
- 安全
- web 安全
- XSS
- CSRF
- SQL 注入
- 腳本注入
- 漏洞掃描工具
- 驗證碼
- DDoS 防范
- 用戶隱私信息保護
- 加密解密
- 對稱加密
- 哈希算法
- 非對稱加密
- 服務器安全
- 數據安全
- 網絡隔離
- 授權、認證
- RBAC
- OAuth2.0
- 單點登錄(SSO)
- JWT
- 開源框架
- 開源協議
- 日志框架
- ORM
- PHP開源框架
- 分布式集群
- 擴展性設計
- 穩定性高可用
- 數據庫擴展
- 分布式一致
- 分布式文件系統
- 開發模式
- DDD(Domain-driven Design - 領域驅動設計)
- Actor 模式
- 響應式編程
- DODAF2.0
- Serverless
- Service Mesh
- 項目管理
- 架構評審
- 重構
- 代碼規范
- 代碼 Review
- 看板管理
- 敏捷開發
- 極限編程
- PDCA 循環質量管理
- FMEA管理模式
- 資訊
- 行業資訊
- 公眾號列表
- 博客
- 綜合門戶、社區
- 技術資源
- 開源資源
- 手冊、文檔、教程
- 在線課堂
- 代碼托管
- 云服務商