C++11写算法之插入排序
插入排序,是指将从1 –> size-1的数一个个插入到前面已经排序好的数组中。
时间复杂度:O(n^2) , O(nlgn) (lgn指使用二分查找插入点位置)
空间复杂度:O(1)
// #if __cplusplus < 201103L
// #error "must be compiled under c++11 support platform!!!"
// #endif
#include <iostream>
#include <algorithm>
#include <iterator>
#include <cassert>
using namespace std; //find insert position function
int FindInsertPos(int varList[], const int size, const int target)
{
if (!varList || size < 0)
{
assert(false);
return -1;
}
int insertPos = 0;
for (int i = 0; i < size;i++)
{
if (target < varList[i])
{
insertPos = i;
break;
}
}
return insertPos;
}
//binary find insert position function
int BinaryFindInsertPos(int varList[], const int size,const int target)
{
if (!varList || size < 0)
{
assert(false);
return -1;
}
int insertPos = 0;
int begin = 0;
int end = size - 1;
int mid = (begin + end) >> 1;
while (begin < end)
{
if (target > varList[begin] && target <= varList[mid] && 1 == (mid - begin))
{
insertPos = mid;
break;
}
else if (target > varList[mid] && target < varList[end] && 1 == (end - mid))
{
insertPos = end;
break;
}
else if (target < varList[mid])
{
end = mid - 1;
}
else if (target > varList[mid])
{
begin = mid + 1;
}
mid = (begin + end) >> 1;
} return insertPos;
}
//insert sort function
void InsertSort(int varList[], const int size)
{
if (!varList || size <= 1)
{
return;
}
auto findInsertPosFunc = BinaryFindInsertPos; //FindInsertPos
for (int i = 1; i < size; i++)
{
if (varList[i - 1] > varList[i])
{
int tmp = varList[i];
int insertPos = findInsertPosFunc(varList, i, varList[i]);
//move
for (int j = i; j > insertPos;j--)
{
varList[j] = varList[j - 1];
}
varList[insertPos] = tmp;
}
}
} void test()
{
//case counter
int testCase = 0;
//sort function object
auto sortFunc = InsertSort;
//show case result lambda function
auto showFunc = [&testCase](const char* caseDescription){cout << "case[" << testCase++ << "]\t(" << caseDescription << ") \t\tok " << endl; }; cout << "test begin : " << endl << endl; //case empty list
{
sortFunc(nullptr, 0);
showFunc("case empty list");
}
//case wrong size
{
int nTestList[] = { 13, 52, 32, 15, 66, 2, 99, 202, 103, 2 };
sortFunc(nTestList, 0);
showFunc("case wrong size");
}
//case size == 1
{
int var = 13;
int varList[] = { var };
sortFunc(varList, 1);
assert(var == varList[0]);
showFunc("case size == 1");
}
//case normal sort
{
int varList[] = { 13, 52, 32, 15, 66, 2, 99, 202, 103, 2 };
const int size = sizeof(varList) / sizeof(int);
const int resultList[] = { 2, 2, 13, 15, 32, 52, 66, 99, 103, 202 };
static_assert(sizeof(varList) == sizeof(resultList), "size of varList is not equal with resultList!!"); sortFunc(varList, size);
for (int i = 0; i < size; i++){ assert(varList[i] == resultList[i]); }
showFunc("case normal sort");
}
//case sorted list
{
int varList[] = { 2, 2, 13, 15, 32, 52, 66, 99, 103, 202 };
const int size = sizeof(varList) / sizeof(int);
const int resultList[] = { 2, 2, 13, 15, 32, 52, 66, 99, 103, 202 };
static_assert(sizeof(varList) == sizeof(resultList), "size of varList is not equal with resultList!!"); sortFunc(varList, size);
for (int i = 0; i < size; i++){ assert(varList[i] == resultList[i]); }
showFunc("case sorted list");
}
cout << endl << "test done ! " << endl << endl;
}
int main(int argc, char* argv[])
{
test();
return 0;
}
C++11写算法之插入排序的更多相关文章
- C++11写算法之顺序查找
从这篇博文起,将尝试使用C++11来写常用算法与数据结构. 本篇博文以最简单的顺序查找作为系列博文的起点,并作约定如下: 1,变量名 : varList : 函数名 : SequentialFind ...
- C++11写算法之二分查找
同样的,二分查找很好理解,不多做解释,要注意二分查找的list必须是排好序的. 这里实现了两种二分查找的算法,一种递归一种非递归,看看代码应该差不多是秒懂.想试验两种算法,改变一下findFunc函数 ...
- C++11写算法之选择排序
选择排序,顾名思义,指从数组后面将最小的值找出来,然后与最前面(指当前位置)值进行交换. 时间复杂度:O(n^2) 空间复杂度:O(1) 此处应用了C++11的auto , lambda , stat ...
- C++11写算法之冒泡排序
冒泡排序很形象,指从数组后面将更小的值慢慢浮到前面去,每遍历一趟使得最小值浮到最前面(指当前位置). 这里有点小技巧,当某一次遍历过程中发现无交换,则说明此时数组已经排序完成,可提前退出. 时间复杂度 ...
- 算法分析中最常用的几种排序算法(插入排序、希尔排序、冒泡排序、选择排序、快速排序,归并排序)C 语言版
每次开始动手写算法,都是先把插入排序,冒泡排序写一遍,十次有九次是重复的,所以这次下定决心,将所有常规的排序算法写了一遍,以便日后熟悉. 以下代码总用一个main函数和一个自定义的CommonFunc ...
- 【算法】插入排序 insertion_sort
准备写个<STL 源代码剖析>的读书笔记,开个专栏.名为<STL 的实现>,将源代码整理一遍.非常喜欢侯捷先生写在封底的八个字:天下大事.必作于细.他在书中写到:"我 ...
- 一步一步写算法(之挑选最大的n个数)
原文:一步一步写算法(之挑选最大的n个数) [ 声明:版权所有,欢迎转载,请勿用于商业用途. 联系信箱:feixiaoxing @163.com] 从一堆数据中挑选n个最大的数,这个问题是网上流传的 ...
- m_Orchestrate learning system---二十一、怎样写算法比较轻松
m_Orchestrate learning system---二十一.怎样写算法比较轻松 一.总结 一句话总结:(1.写出算法步骤,这样非常有利于理清思路,这样就非常简单了 2.把问题分细,小问题用 ...
- arcgis api for js共享干货系列之一自写算法实现地图量算工具
众所周知,使用arcgis api for js实现地图的量算工具功能,无非是调用arcgisserver的Geometry服务(http://localhost:6080/arcgis/rest/s ...
随机推荐
- CSS3 transform变换
CSS3 transform变换 1.translate(x,y) 设置盒子位移2.scale(x,y) 设置盒子缩放3.rotate(deg) 设置盒子旋转4.skew(x-angle,y-angl ...
- JavaScript里面向对象的继承:不使用构造函数实现"继承"
一.什么是"非构造函数"的继承? //比如,现在有一个对象,叫做"中国人". var Chinese = { nation:'中国' }; //还有一个对象,叫 ...
- 转:http2的资料与使用
https://imququ.com/post/http2-resource.html
- JavaScript完整性检查
1.7个“坑” <!DOCTYPE html> <html lang="zh"> <head> <meta charset="U ...
- Python基础--人们一些最爱的标准库(random time)
Python继续! random 包括返回随机数的函数. 这里跟C++一样,产生的是伪随机数,并非全然随机数. random中一些重要的函数: random() 返回0<n<=1的随机数n ...
- android 调用系统界面
现在开发中的功能需要直接跳转到拨号.联系人.短信界面等等,查找了很多资料,自己整理了一下. 首先,我们先看拨号界面,代码如下: Intent intent =new Intent(); intent. ...
- URL.createObjectURL()
URL.createObjectURL() 静态方法会创建一个 DOMString,其中包含一个表示参数中给出的对象的URL.这个 URL 的生命周期和创建它的窗口中的 document 绑定.这个新 ...
- C# Enum,Int,String,之间及bool与int之间的转换
枚举类型的基类型是除 Char 外的任何整型,所以枚举类型的值是整型值. Enum 提供一些实用的静态方法: (1)比较枚举类的实例的方法 (2)将实例的值转换为其字符串表示形式的方法 (3)将数字的 ...
- jq时间戳转化为可视化时间
//2016年5月21日 23:12:07 function getDateTimeToDate(dt){ var dateTime = new Date(dt); var date = dateTi ...
- CentOS 6.5 X64 U盘启动盘制作
本教程是在Linux系统下制件,可以使用虚拟机安装Linux 1.准备一个8G的U盘,在Linux下分成Fat32---500M----root, 剩下的分成Ext3 ----data,并格式化. 2 ...