C++實(shí)現(xiàn)折半插入排序(BinaryInsertSort)
本文實(shí)例為大家分享了C++實(shí)現(xiàn)折半插入排序的具體代碼,供大家參考,具體內(nèi)容如下
一、思路:
較插入排序,減少了比較的次數(shù),但是插入時(shí)間還是一樣。
(1)按二分查找的方法,查找V[i]在V[0],V[1]…V[i-1]中插入的位置;
(2)將插入位置的元素向后順移。
二、實(shí)現(xiàn)程序:
// 二分插入:較插入排序,減少了比較的次數(shù),但是插入時(shí)間還是一樣
// 時(shí)間復(fù)雜度還是:O(n*n)
#include <iostream>
using namespace std;
const int maxSize = 20;
template <class T>
void BinInsertSort(T arr[], const int left, const int right) {
int i, j, low, high, mid;
T temp;
for(i = left+1; i <= right; i++) {
temp = arr[i]; // 暫存arr[i]
low = left;
high = i-1; // low、high作為折半查找的上、下界
while(low <= high) { // 用折半查找的方法,查找arr[i]的插入位置
mid = (low + high) / 2;
if(temp < arr[mid])
high = mid - 1;
else
low = mid + 1;
} // while
for(j = i-1; j >= low; j--)
arr[j+1] = arr[j]; // 順序后移
arr[low] = temp; // 回填
} // for
} // BinInsertSort
int main(int argc, const char * argv[]) {
int i, n, arr[maxSize];
cout << "請(qǐng)輸入要排序的數(shù)的個(gè)數(shù):";
cin >> n;
cout << "請(qǐng)輸入要排序的數(shù):";
for(i = 0; i < n; i++)
cin >> arr[i];
cout << "排序前:" << endl;
for(i = 0; i < n; i++)
cout << arr[i] << " ";
cout << endl;
BinInsertSort(arr, 0, n-1);
cout << "排序后:" << endl;
for(i = 0; i < n; i++)
cout << arr[i] << " ";
cout << endl;
return 0;
}
測(cè)試結(jié)果:

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++循環(huán)隊(duì)列實(shí)現(xiàn)模型
這篇文章主要介紹了C++循環(huán)隊(duì)列實(shí)現(xiàn)模型,較為詳細(xì)的分析了循環(huán)隊(duì)列算法的原理與實(shí)現(xiàn)方法,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12
Opencv基于文字檢測(cè)去圖片水印的實(shí)現(xiàn)示例
去水印是個(gè)麻煩事,本文就來介紹一種方法Opencv基于文字檢測(cè)去圖片水印的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09
C++?如何將Lambda轉(zhuǎn)換成函數(shù)指針
這篇文章主要介紹了C++?如何將Lambda轉(zhuǎn)換成函數(shù)指針,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11
C++中關(guān)于[]靜態(tài)數(shù)組和new分配的動(dòng)態(tài)數(shù)組的區(qū)別分析
這篇文章主要介紹了C++中關(guān)于[]靜態(tài)數(shù)組和new分配的動(dòng)態(tài)數(shù)組的區(qū)別分析,很重要的概念,需要的朋友可以參考下2014-08-08
opencv3/C++ 使用Tracker實(shí)現(xiàn)簡(jiǎn)單目標(biāo)跟蹤
今天小編就為大家分享一篇opencv3/C++ 使用Tracker實(shí)現(xiàn)簡(jiǎn)單目標(biāo)跟蹤,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12

