数据结构之 排序---折半插入排序(时间复杂度 O(nlog2 n) )
排序
Time Limit: 1000MS Memory limit: 32678K
题目描述
给你N(N<=100)个数,请你按照从小到大的顺序输出。
输入
输入数据第一行是一个正整数N,第二行有N个整数。
输出
输出一行,从小到大输出这N个数,中间用空格隔开。
示例输入
5
1 4 3 2 5
示例输出
1 2 3 4 5
#include <math.h>
#include <string.h>
#include <stdio.h>
#include <iostream>
#include <string>
#include <algorithm> using namespace std; //折半插入排序
void B_insertsort(int a[], int n)
{
int i, j;
int mid, low, high; for(i=2; i<=n; i++)
{
a[0]=a[i]; //a[0] 只是我写的这个算法模板的“中转站”,实际数据存在下标: 1--->n 里面
low=1; high=i-1;
while(low <= high)
{
mid = (low+high)/2;
if(a[0]>a[mid]) // 此语句将决定是“由大到小” 还是 “由小到大”排序的顺序!
low=mid+1;
else
high=mid-1;
}
for(j=i-1; j>=high+1; j--)
{
a[j+1]=a[j];
}
a[high+1]=a[0];
}
} int main()
{
int a[200];
int i, j;
int n;
while(~scanf("%d", &n))
{
for(i=1; i<=n; i++)
{
cin>>a[i];
}
B_insertsort(a, n); for(j=1; j<=n; j++)
{
if(j==1)
cout<<a[j];
else
cout<<" "<<a[j];
}
cout<<endl;
}
return 0;
}
数据结构之 排序---折半插入排序(时间复杂度 O(nlog2 n) )的更多相关文章
- 算法与数据结构(十三) 冒泡排序、插入排序、希尔排序、选择排序(Swift3.0版)
		本篇博客中的代码实现依然采用Swift3.0来实现.在前几篇博客连续的介绍了关于查找的相关内容, 大约包括线性数据结构的顺序查找.折半查找.插值查找.Fibonacci查找,还包括数结构的二叉排序树以 ... 
- Java常见排序算法之折半插入排序
		在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ... 
- 直接插入排序、折半插入排序、Shell排序、冒泡排序,选择排序
		一.直接插入排序 稳定,时间复杂度:最好O(n).最差O(n^2).平均O(n^2).空间复杂度O(1) void InsertSort(int L[], int n) { int i, j,key; ... 
- 排序算法之折半插入排序的思想以及Java实现
		1 基本思想 折半插入排序(binary insertion sort)的基本原理与直接插入排序相同,不同之处在于,确定当前记录在前面有序子数组中的位置时,直接插入排序是采用顺序查找的方法,而折半插入 ... 
- 内部排序->插入排序->其它插入排序->折半插入排序
		文字描述 和直接插入排序比较,只是把“查找”操作利用“折半查找”来实现,由此进行的插入排序叫做折半插入排序. 示意图 略 算法分析 和直接插入排序比,减少了比较次数,但是移动次数没有变,所以折半插入排 ... 
- 数据结构和算法(Golang实现)(21)排序算法-插入排序
		插入排序 插入排序,一般我们指的是简单插入排序,也可以叫直接插入排序.就是说,每次把一个数插到已经排好序的数列里面形成新的排好序的数列,以此反复. 插入排序属于插入类排序算法. 除了我以外,有些人打扑 ... 
- 排序系列 之 折半插入排序算法 —— Java实现
		基本思想: 折半插入算法是对直接插入排序算法的改进,排序原理同直接插入算法: 把n个待排序的元素看成一个有序表和一个无序表,开始时有序表中只有一个元素,无序表中有n-1个元素:排序过程即每次从无序表中 ... 
- IOS- 快速排序,冒泡排序,直接插入排序和折半插入排序,希尔排序,堆排序,直接选择排序
		/*******************************快速排序 start**********************************///随即取 当前取第一个,首先找到第一个的位置 ... 
- Java数据结构和算法总结-冒泡排序、选择排序、插入排序算法分析
		前言:排序在算法中的地位自然不必多说,在许多工作中都用到了排序,就像学生成绩统计名次.商城商品销量排名.新闻的搜索热度排名等等.也正因为排序的应用范围如此之广,引起了许多人深入研究它的兴趣,直至今天, ... 
随机推荐
- 洛谷P3393 逃离僵尸岛
			题目描述 小a住的国家被僵尸侵略了!小a打算逃离到该国唯一的国际空港逃出这个国家. 该国有N个城市,城市之间有道路相连.一共有M条双向道路.保证没有自环和重边. K个城市已经被僵尸控制了,如果贸然闯入 ... 
- jQuery事件委托之Safari失效的解决办法--摘抄
			什么是事件委托 事件委托是Jquery中一种事件绑定的方式,不同于常见的事件绑定方式将事件绑定在目标元素上,而是将事件绑定在父级元素上通过事件冒泡来执行绑定函数. //常见的事件绑定(Jquery) ... 
- Laravel 修改操作
			增加路由: Route::any('Student/update/{id}',['uses'=>'StudentController@update']); 控制器代码:(Request $req ... 
- Jetson TK1 三:项目相关安装
			ROS.QT.pyserial2.7.罗技手柄驱动.navigation.slam和rviz等 激光雷达IP设置,tk1对应的IP设置,tk1串口设置 一.安装ros参见官网 二.安装QT 百度QT官 ... 
- AbstractQueuedSynchronizer 队列同步器源码分析
			AbstractQueuedSynchronizer 队列同步器(AQS) 队列同步器 (AQS), 是用来构建锁或其他同步组件的基础框架,它通过使用 int 变量表示同步状态,通过内置的 FIFO ... 
- android  播放MP3
			<?xml version="1.0" encoding="utf-8"?> <!-- 定义当前布局的基本LinearLayout --> ... 
- BUPT复试专题—字符串转换(2013计院)
			题目描述 我们将仅由若干个同一小写字母构成的字符串称之为简单串,例如"aaaa"是一个简单串,而"abcd"则不是简单串.现在给你一个仅由小写字母组成的字符串, ... 
- 一根数据线玩转树莓派Zero
			0. 前言 原创文章,转载引用务必注明链接.水平有限,如有疏漏,欢迎指正. 本文使用Markdown写成,为获得更好的阅读体验和正常的链接.图片显示,请访问我的博客原文: http://www.cnb ... 
- PHP生成excel(1)
			先到PHPExcel官网下载PHPExcel类 http://phpexcel.codeplex.com/ 把excel类包含进来,然后直接使用 <?php require "./PH ... 
- 使用session来存储用户的登录信息
			对存在cookie端数据进行加密处理,具体代码如下: <?php session_start(); //假设用户登录成功获得了以下用户数据 $userinfo = array( 'uid' =& ... 
