当前位置: 首页 > 编程日记 > 正文

怎样写出一个较好的高速排序程序

写出一个较好的高速排序程序

  • 高速排序是经常使用的排序算法之中的一个,但要想写出一个又快又准的使用程序,就不是那么简单了

须要注意的事项

  • 首先要写正确。通常使用递归实现。其递归相当于二叉树展开,因此假设要用迭代实现的话须要使用一个队列来保存兴许遍历信息。
  • 高速排序须要找到一个pivot值,假设顺序选择pivot则易造成N^2的复杂度,假设使用随机数则效果最好,但开销又太大,採取三数中值法比較合适。三数中值法指的是选取第一个值,最后一个值,数组中间的值的中值。有文献表明能够提升5%的执行时间。
  • 当数组长度较小时,如10个元素下面,最好使用插入排序或者选择排序完毕,以防止复杂度常数因子过大或多次函数调用带来的开销。而递归究竟层数组长度总是会变小的,因此这么做很有必要。
  • 在合并前后两部分数组时,採用两边夹方法,在前后两部分各找到一个大于和小于的值再交换。相比通常情况下找到比pivot小的值就进行交换,能提高执行效率。

实现代码

  • 代码例如以下。包含插入排序insert_sort,递归函数,三分中值函数三个辅助函数。
  • 三分中值函数事实上採用的是插入排序。通过三次比較,确定中值。
  • 插值算法使用暂时变量tmp避免了大量swap函数调用。
#include<iostream>
#include<iomanip>
#include<vector>
#include<cstdlib>
#include<ctime>
#include<algorithm>using namespace std;inline void swap(vector<int>& num, int p, int q){int t = num[p];num[p] = num[q];num[q] = t;
}void insert_sort(vector<int>& num){int tmp, j;for (int i = 1; i < num.size(); i++){tmp = num[i];for (j = i - 1; j >= 0 && num[j] > tmp; j--)num[j + 1] = num[j];num[j + 1] =tmp;}
}int quick_sort_sub(vector<int>& num, int p, int q){if (p >= q)return 0;// if 4 elements or less, use insert sortif (p + 10 > q){vector<int> tnum(num.begin() + p, num.begin() + q + 1);insert_sort(tnum);for (int i = 0; i < tnum.size(); i++)num[p + i] = tnum[i];}int idx = quick_three_partition(num, p, q);swap(num, idx, q);int pivot = num[q];int left = p, right = q - 1;while (1){while (num[left] < pivot)++left;while (num[right] >= pivot)--right;if (left < right)swap(num, left, right);elsebreak;}swap(num, left, q);quick_sort_sub(num, p, left - 1);quick_sort_sub(num, left + 1, q);return left;
}void quick_sort(vector<int>& num){quick_sort_sub(num, 0, num.size() - 1);
}int main(){const int n = 10;/*int num_array[n]= {2,1};vector<int> num(num_array, num_array + n);*/srand( time(NULL) );vector<int> num(n);for (auto& e : num)e = rand() % n;quick_sort(num);for (auto& e : num)cout << setw(4) << e << ' ';cout << endl;cout << "vector is sorted? : " << is_sorted(num.begin(), num.end()) << endl;return 0;}


转载请注明作者:Focustc,博客地址为http://blog.csdn.net/caozhk,原文链接为点击打开

相关文章:

写代码时发现......还得是 SpringBoot !一篇拿下

关注了很多技术类公众号的读者肯定有这样一个感受&#xff0c;SpringBoot相关的文章铺天盖地&#xff0c;并且SpringBoot相关的文章阅读量、收藏量都很高&#xff0c;这也从侧面反映了SpringBoot技术的火爆。一切都在证明&#xff0c;SpringBoot已经成为了Java程序员必备的技能…

Python的 if .else.elif语句详解

If 语句 是用来判断的 Python 编程中 if 语句用于控制程序执行 用来检测一个条件&#xff1a;如果条件为 &#xff08;真&#xff09;true&#xff0c;就会运行这个语法块&#xff0c;如果为Fales 就跳过不执行。 elif是依附于if存在的&#xff0c;两者之间的运算逻辑相同&…

C#中string与byte[]的转换帮助类

在写C&#xff03;程序时&#xff0c;string和byte[]之间的转换比较烦&#xff0c;在移植一些老程序时感觉很不好。我在C&#xff03;中使用DES和TripleDES时移植一块老代码时也遇到了同样的情况。为了下次不为同样的事情烦恼&#xff0c;就写了下面的帮助类。 主要实现了以下…

鲲鹏入晋 万里腾飞,鲲鹏应用创新大赛2021山西赛区邀你来战!

2021 年 6 月 29 日&#xff0c;由山西省工业和信息化厅、山西转型综合改革示范区管理委员会为指导单位&#xff0c;华为技术有限公司主办&#xff0c;山西鲲鹏生态创新中心暨华为&#xff08;山西综改区&#xff09;DevCloud 创新中心承办&#xff0c;山西长河科技股份有限公司…

tcpdump-根据IP查看程序与服务都用了哪些端口

tcpdump -i em1 -tttt src 116.3.248.157 and port ! 6869 -nn -i 指定端口 -tttt 附带时间戳 -nn 解析域名与端口信息 ############################################# windows下可以使用netstat -nb |find “18999” 与 netstat -ao 结合使用&#xff0c;在通过pid号 查看进程…

快速构建Windows 8风格应用27-漫游应用数据

本篇博文主要介绍漫游应用数据概览、如何构建漫游应用数据、构建漫游应用数据最佳实践。 漫游应用数据概览 1.若应用当中使用了漫游应用数据&#xff0c;用户可以很轻松的在不同的设备间保持应用数据的同步。 2.Windows会将更新的漫游数据同步到云端&#xff0c;并将数据更新到…

jquery和css3打造超梦幻的三维动画背景

今天为大家带来的是一款由jquery和css3实现的超级梦幻的背景效果。绿色的小原点由远到近&#xff0c;由近到远一种飞跃效果。效果非常好看&#xff0c;我们一起看下效果图&#xff1a; 在线预览 源码下载 我们一起看下实现的代码。这是一款由jquey和css3实现的效果。这里引用…

C#时间函数扩展

//本周是本年第几周 private int DatePart(System.DateTime dt) { int weeknow Convert.ToInt32(dt.DayOfWeek);//今天星期几 int daydiff (-1) * (weeknow1);//今日与上周末的天数差 int days System.DateTime.Now.AddDays(daydiff).DayOfYear;//上周末是本年第几天 i…

“我被机器解雇了!”Amazon 63岁员工因算法评分太低被自动开除

整理 | Carol出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09;“我被一个机器解雇了。”63岁“老司机”因跟踪算法被开除一觉醒来&#xff0c;63岁的斯蒂芬 诺曼丁&#xff08;Stephen Normandin&#xff09;发现自己居然被莫名其妙解雇了。斯蒂芬是Amazon Flex的一…

微信开放平台手机APP支付

PHP对接APP微信支付 微信开放平台手机APP支付总结 1. 微信开放平台手机APP支付总结 支付功能链接: https://pay.weixin.qq.com/wiki/doc/api/index.html APP支付功能文档: https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter8_3 Demo下载地址: https://pay.weixin.q…

VS2005创建CLR自定义触发器

第一步&#xff1a;在Visual Studio 2005中编写代码 using System; using System.Data; using System.Data.Sql; using System.Data.SqlServer; using System.Data.SqlTypes; public partial class Triggers { // Enter existing table or view for the target and unc…

Adobe推出HTML5动画设计工具Edge

2019独角兽企业重金招聘Python工程师标准>>> HTML5和Flash&#xff0c;是敌对&#xff1f;是共存&#xff1f; 尽管Flash现在依然牢牢占据着网络动画的大半江山&#xff0c;但这种状况终将会被改变。 那么&#xff0c;Edge的推出是否意味着Adobe将放弃和屈服于Flash…

AI 算法给手画线稿自动上色指南来了

测试图片作者 | 叶庭云来源 | 修炼Python生成线稿图像手绘效果的特征&#xff1a;黑白灰色、边界线条较重、相同或相近色彩趋于白色、略有光源效果。手绘风格是在对图像进行灰度化的基础上由立体效果和明暗效果叠加而成的&#xff0c;灰度实际代表了图像的明暗变化&#xff0c;…

mysqldump和xtrabackup备份原理实现说明

MySQL数据库备份分为逻辑备份和物理备份两大类&#xff0c;犹豫到底用那种备份方式的时候先了解下它们的差异&#xff1a; 逻辑备份的特点是&#xff1a;直接生成SQL语句&#xff0c;在恢复的时候执行备份的SQL语句实现数据库数据的重现。物理备份的特点是&#xff1a;拷贝相关…

C语言100个经典的算法

POJ上做做ACM的题 语言的学习基础,100个经典的算法C语言的学习要从基础开始&#xff0c;这里是100个经典的算法&#xff0d;&#xff11;C语言的学习要从基础开始&#xff0c;这里是100个经典的算法 题目&#xff1a;古典问题&#xff1a;有一对兔子&#xff0c;从出生后第3个月…

PornHub:修复百年前情色电影

全球最大不可描述网站 PornHub 最近在自己的官网上&#xff0c;注册了一个名为 「Remastured」的视频发布账号&#xff0c;中文意为「重制」。截止目前&#xff0c;这个账号已经上传了 21 个视频&#xff08;包含一部项目介绍视频&#xff09;&#xff0c;共计两万的订阅用户和…

jquery 插件开发的作用域及基础

2019独角兽企业重金招聘Python工程师标准>>> 之前一直有开发jquery插件的冲动&#xff0c;所以一直想学习如何进行插件开发&#xff0c;最近一个项目需要使用图片上传组件及自动无限下拉组件&#xff0c;百度地图组件&#xff0c;所以趁着这次我就把他们全部插件化了…

WSUS Troubleshooting guide

Troubleshooting guide for issues where WSUS clients are not reporting in 来自于WSUS TEAM BLOG This guide is written to assist specifically in troubleshooting WSUS when clients are not reporting in. We will examine common troubleshooting considerations that…

在PHP语言中使用JSON

从5.2版本开始&#xff0c;PHP原生提供json_encode()和json_decode()函数&#xff0c;前者用于编码&#xff0c;后者用于解码。 一、json_encode() 该函数主要用来将数组和对象&#xff0c;转换为json格式。先看一个数组转换的例子&#xff1a; $arr array (a>1,b>2,c&g…

【动态规划】最长公共子序列与最长公共子串

1. 问题描述 子串应该比较好理解&#xff0c;至于什么是子序列&#xff0c;这里给出一个例子&#xff1a;有两个母串 cnblogsbelong比如序列bo, bg, lg在母串cnblogs与belong中都出现过并且出现顺序与母串保持一致&#xff0c;我们将其称为公共子序列。最长公共子序列&#xff…

限量!“Java成长笔记”Spring Boot/Sentinel/Nacos高并发

前言本文是为了帮大家快速回顾了Java中知识点&#xff0c;这套面试手册涵盖了诸多Java技术栈的面试题和答案&#xff0c;相信可以帮助大家在最短的时间内用作面试复习&#xff0c;能达到事半功倍效果。本来想将文件上传到github上&#xff0c;但由于文件太大有的都无法显示所以…

时区切换导致quartz定时任务没有触发问题

时区切换对Quartz的cron表达式有影响&#xff0c;切换的1小时内停止触发定时任务&#xff0c;导致sla没有定时清空内存计数&#xff0c;误发限流。 美国夏令时PST切换到冬令时PDT&#xff0c;会有时间跳变。不带时区跳变的&#xff0c;会出现时间重叠或不连续 问题复现 mac本机…

C#之消息队列的简要说明

using System; using System.Drawing; using System.Collections; using System.ComponentModel; using System.Windows.Forms; using System.Data; using System.Messaging ; using System.Threading ; namespace WinMsmq { /// <summary> /// Form1 的摘要说…

Arm收购进展、元宇宙、GPU涨价……听听黄仁勋怎么说

今年的台北国际电脑展 (Computex) 于 6 月 1-5 日在线上召开&#xff0c;期间 NVIDIA CEO 黄仁勋接受了媒体的线上群访&#xff0c;本文对采访内容进行了翻译与整理。对厨房情有独钟的黄教主&#xff0c;走出了厨房&#xff0c;选择了 NVIDIA 新办公大楼 Voyager&#xff08;旅…

要立刷金组flag了T_T

刷了那么多银组&#xff0c;发现自己好多不会啊... 果然太弱 在这感谢hzwer神犇的blog。。 大部分题解都从黄学长这里来orz。 orz。。。。 果然我太水

Centos7更改root密码

方法一#Step1&#xff1a;重启linux命令&#xff1a;rebootinit 6shutdown -r now#Step2&#xff1a;进grub改启动参数启动界面按“e”ro 改为rw init/sysroot/bin/shCtrlX保存做的更改&#xff0c;这时已经进入操作界面了#Step3&#xff1a;CtrlD然后init 6重启电脑&#xff0…

C#实现Des加密和解密

using System; using System.IO; using System.Security.Cryptography; namespace Vavic { /// <summary> /// Security 的摘要说明。 /// </summary> public class Security { const string KEY_64 "VavicApp"; const string IV_64 "V…

10 行代码玩转 NumPy!

作者 | 天元浪子来源 | Python作业辅导员NumPy也可以画图吗&#xff1f;当然&#xff01;NumPy不仅可以画&#xff0c;还可以画得更好、画得更快&#xff01;比如下面这幅画&#xff0c;只需要10行代码就可以画出来。若能整明白这10行代码&#xff0c;就意味着叩开了NumPy的大门…

秘钥加密码的登录模式

应用场景&#xff1a;有时候我们要给远在北京或者国外的开发人员服务器的权限&#xff0c;为了保证服务器的安全性我们不想让他们知道服务器的root登陆密码&#xff0c;所以我们可以给他们用秘钥加密码的登陆模式。原理&#xff1a;公钥加密 私钥解密。公钥和私钥是成对生成的&…

【C#小知识】C#中一些易混淆概念总结(七)---------解析抽象类,抽象方法

目录&#xff1a; 【C#小知识】C#中一些易混淆概念总结--------数据类型存储位置&#xff0c;方法调用&#xff0c;out和ref参数的使用 【C#小知识】C#中一些易混淆概念总结&#xff08;二&#xff09;--------构造函数&#xff0c;this关键字&#xff0c;部分类&#xff0c;枚…