折半插入排序

来源:互联网 发布:软件测试技术pdf 编辑:程序博客网 时间:2024/06/05 21:16

这个是在上一篇插入排序的基础上的改进。在查找第i个元素的正确位置的过程中,使用折半查找加速。数据量大的情况下效率应该有比较显著的提升。

//折半插入排序//lovesunmoonlight//2017.3.24 #include<iostream>#include<cmath>#include<cstdlib>using namespace std;#define MAX 10typedef struct{int key; //关键字 double data; //数据 }node;typedef struct{node r[MAX+1]; //r[0]的位置设置为哨兵int len; }List;void binaryInsertSort(List& s){for(int i=2;i<s.len;i++){s.r[0]=s.r[i]; //保存到哨兵int low=1;int high=i-1;int mid=low+(high-low)/2;while(low<=high){if(s.r[0].key<s.r[mid].key){high=mid-1;}else{low=mid+1; }mid=low+(high-low)/2;}int j;for(j=i-1;j>=high+1;j--){s.r[j+1]=s.r[j];}s.r[high+1]=s.r[0];}}void output(const List& s){cout<<"Key Data"<<endl;for(int i=1;i<s.len;i++)cout<<s.r[i].key<<" "<<s.r[i].data<<endl;cout<<endl;}int main(){List s;//初始化表 s.len=MAX+1;s.r[0].key=0;s.r[0].data=-1;for(int i=1;i<s.len;i++){s.r[i].data=rand()%100;s.r[i].key=rand()%50;}cout<<"Initialized: "<<endl;output(s);binaryInsertSort(s);cout<<"After binaryInsertSort: "<<endl;output(s); return 0;} 
结果:




0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 微商退货后不退款怎么办 有赞买东西付款没发货怎么办 赞礼号掉了东西怎么办 万达贷系统维护还不了款怎么办 qq文件发不出去怎么办 1688分销没有传淘宝怎么办 京东的货运代理怎么办 天天练推广期没了怎么办 微信自动建群怎么办 刚刚不小心扫了无痕爆客怎么办 苹果6升级卡死怎么办 随行付换手机了怎么办 融e联账号冻结怎么办 58同城高危账户怎么办 网购迟迟不发货怎么办 优酷不能投屏了怎么办 爱尚街借款不还怎么办 小米商城买东西没收到货怎么办 微信投票地区限制怎么办 微信退款未到账怎么办 微信钱包锁忘了怎么办 xp系统管理员密码忘了怎么办 沃尔沃menu键没反应怎么办 微信转账受限制怎么办 被米虎网骗了手里还有合同怎么办 学校要求上传论文pdf格式怎么办 备份的Wifi密码查看乱码怎么办 u盘密码忘了怎么办 京东会员号被黑怎么办 淘宝企业店铺三证不合一怎么办 淘宝企业店铺营业执照注销了怎么办 不想开淘宝企业店铺了怎么办 id图片跨页排版怎么办 合约机不想要了怎么办? 移动A3手机老卡怎么办 中国移动手机a3很卡怎么办 移动手机a4好卡怎么办 红米手机卡顿反应慢怎么办 红米3s网速慢怎么办 红米4a内存不足怎么办 红米3s手机发热怎么办