C++折半插入排序
代码如下:
#include <iostream>
using namespace std;
void insertSort(int a[], int n)
{
    for(int i=1;i<n;++i)
    {
        if(a[i]<a[i-1])
        {
           int low = 0;
           int high = i-1;
           int j;
           int temp = a[i];
           while(low<=high)
           {
               int mid=(low+high)/2;
               if(a[mid]==a[i])
               {//将a[i]放在a[mid]右边
                   for( j=i-1;j>mid;--j)
                   {
                       a[j+1]=a[j];
                   }
                 a[mid+1] = temp;
               }
               else if(a[mid]<a[i])
               {
                   low=mid+1;
               }
               else
               {
                   high=mid-1;
               }
           }
           if(low>high)/*说明当前插入的元素不在已排好序的数列中,此时应该将元素放在index等于low处,或者index等于high+1处;*/
           {
               for( j=i-1;j>=low;--j)
                   {
                       a[j+1]=a[j];
                   }
                   a[low] = temp;
           }
        }
    }
}
int main()
{
    const int N=7;
    int a[]={3,1,7,9,2,5,4};
    insertSort(a,N);
    for(int i=0;i<N;++i)
    {
        cout<<a[i]<<" "<<endl;
    }
    return 0;
}
C++折半插入排序的更多相关文章
- 排序系列 之 折半插入排序算法 —— Java实现
		基本思想: 折半插入算法是对直接插入排序算法的改进,排序原理同直接插入算法: 把n个待排序的元素看成一个有序表和一个无序表,开始时有序表中只有一个元素,无序表中有n-1个元素:排序过程即每次从无序表中 ... 
- IOS- 快速排序,冒泡排序,直接插入排序和折半插入排序,希尔排序,堆排序,直接选择排序
		/*******************************快速排序 start**********************************///随即取 当前取第一个,首先找到第一个的位置 ... 
- Java常见排序算法之折半插入排序
		在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ... 
- 折半插入排序(Binary Insertion Sort)的C语言实现
		原创文章,转载请注明来自钢铁侠Mac博客http://www.cnblogs.com/gangtiexia 折半插入排序(Binary Insertion Sort)的基本思想是将新记录插入到已经 ... 
- Java 实现二分(折半)插入排序
		设有一个序列a[0],a[1]...a[n];当中a[i-1]前是已经有序的,当插入时a[i]时,利用二分法搜索a[i]插入的位置 效率:O(N^2),对于初始基本有序的序列,效率上不如直接插入排序: ... 
- java排序算法(七):折半插入排序
		java排序算法(七):折半插入排序 折半插入排序法又称为二分插入排序法,是直接插入排序法的改良版本,也需要执行i-1趟插入.不同之处在于第i趟插入.先找出第i+1个元素应该插入的位置.假设前i个数据 ... 
- 【java集合框架源码剖析系列】java源码剖析之java集合中的折半插入排序算法
		注:关于排序算法,博主写过[数据结构排序算法系列]数据结构八大排序算法,基本上把所有的排序算法都详细的讲解过,而之所以单独将java集合中的排序算法拿出来讲解,是因为在阿里巴巴内推面试的时候面试官问过 ... 
- 折半插入排序算法的C++实现
		折半插入排序思想和直接插入排序类似. 1)找到插入位置: 2)依次后移正确位置及后面的元素. 区别是查找插入位置的方法不同. 折半插入排序使用的折半查找法在一个已经有序的序列中找到查找位置. 注意,折 ... 
- 排序算法之折半插入排序的思想以及Java实现
		1 基本思想 折半插入排序(binary insertion sort)的基本原理与直接插入排序相同,不同之处在于,确定当前记录在前面有序子数组中的位置时,直接插入排序是采用顺序查找的方法,而折半插入 ... 
- 内部排序->插入排序->其它插入排序->折半插入排序
		文字描述 和直接插入排序比较,只是把“查找”操作利用“折半查找”来实现,由此进行的插入排序叫做折半插入排序. 示意图 略 算法分析 和直接插入排序比,减少了比较次数,但是移动次数没有变,所以折半插入排 ... 
随机推荐
- 使用::before和::after来完成尖角效果
			一.目标 目标完成下图效果: 二.完成 1.分析 在::before和::after伪元素的用法一文中有说到使用::befrore和::after可以完成一个六边形.这个案例是用一个#star-six ... 
- 32-bit ALU [Verilog]
			Based on MIPS Instruction Structure Main Module module Alu( input [31:0] a, // operand 1 input [31:0 ... 
- NOIP2013积木大赛
			题目描述 春春幼儿园举办了一年一度的“积木大赛”.今年比赛的内容是搭建一座宽度为n的大厦,大厦可以看成由n块宽度为1的积木组成,第i块积木的最终高度需要是hi. 在搭建开始之前,没有任何积木(可以看成 ... 
- 第28章 行为型模式大PK
			27.1 策略模式 VS 命令模式 27.1.1 策略模式实现压缩算法 //行为型模式大PK——策略模式和命令模式 //实例:用策略模式实现压缩算法 #include <iostream> ... 
- 第63课 C语言异常处理
			1. 异常的概念 (1)程序在运行过程中可能产生异常 (2)异常(Exception)与Bug的区别 ①异常是程序运行时可预料的执行分支 ②Bug是程序是的错误,是不被预期的运行方式 2. 异常和Bu ... 
- 线程同步以及yield()、wait()、Notify()、Notifyall()
			一.线程同步 1.线程同步的目的是为了保护多个线程访问一个资源时对资源的破坏. 2.线程同步方法是通过锁来实现,每个对象都有切仅有一个锁,这个锁与一个特定的对象关联,线程一旦获取了对象锁,其他访问该对 ... 
- ACCP7.0优化Myschool内侧题
			1) 在SQL Server 中,为数据库表建立索引能够(C ). 索引:是SQL SERVER编排数据的内部方法,是检索表中数据的直接通道 建立索引的作用:大大提高了数据库的检索速度,改善数据库性能 ... 
- Android开发书籍推荐:从入门到精通系列学习路线书籍介绍
			Android开发书籍推荐:从入门到精通系列学习路线书籍介绍 很多时候我们都会不断收到新手的提问"Android开发的经典入门教材和学习路线?"."Android 开发入 ... 
- jQuery语法
			目录: 一.选择网页元素二.改变结果集三.链式操作四.元素的操作五.元素的操作:移动六.元素的操作:复制.删除和创建七.工具方法八.事件操作九.特殊效果 一.选择网页元素这也是jQuery的基本设计思 ... 
- swift中第三方网络请求库Alamofire的安装与使用
			swift中第三方网络请求库Alamofire的安装与使用 Alamofire是swift中一个比较流行的网络请求库:https://github.com/Alamofire/Alamofire.下面 ... 
