快排思路

这里采用传统的方法,没有采用剑指Offer书上的方法。

Java版的比较干净,舍去了不必要的判断和操作,以Java版为准。

  • 排序函数(全部采用闭区间):

    当区间为null或者左指针>=右指针位置 return;//

    partition 当前区间,得到随机枢轴元素的idx。

    对idx分成的左右区间排序。
  • partition函数

    在当前区间,(随机选取一个元素和第一个元素置换),选第一个元素作为枢轴元素,确定它的位置(比它小于等于的放左边,比它大于等于的放右边)

    具体的,采用“东拆西补”的思想,while(i!=j){

    从右遍历找到比枢轴元素小的元素,放到i指向的位置,空出j位置;

    从左遍历找到比枢轴元素大的位置,放到j指向的位置,空出i位置;

    }

    arr[i]=枢轴元素

    return i

其他知识点

生成一个范围内随机数

见代码,这里为包含左右两端点。

srand((unsigned)time(0))用来随机生成随机数种子。rand()生成随机数。

数组做形参

数组具有不能传值的特性,当把数组作为形参,实际是把指向数组首元素的地址作为参数传递。

int partition(int *num,int start,int end)

int partition(int num[],int start,int end)

待解决

异常的解决还需要改,

现在遇到异常会输出:terminating with uncaught exception of type char const*

代码(Java)

public class QuikSort {
public static void main(String[] args) {
int[] arr= {4,5,7,2,2,3};
quickSort(arr,0,arr.length-1);
for(int num:arr) {
System.out.println(num);
}
} public static void quickSort(int[] arr,int low,int high) {
if(arr==null||low>=high) {//
return;
}
int idx=partition(arr,low,high);
quickSort(arr,low,idx-1);
quickSort(arr,idx+1,high);
} public static int partition(int[] arr,int low,int high) {
int key=arr[low];
int i=low;
int j=high;
while(i<j) {
while(i<j&&arr[j]>=key) {//
--j;
}
arr[i]=arr[j];//包含i、j相等情况
while(i<j&&arr[i]<=key) {
++i;
}
arr[j]=arr[i];
}
arr[i]=key;
return i;
}
}

代码(C++)

#include <iostream>
#include <time.h> using namespace std; int randomInRange(int start,int end){
if(end<start){
throw "Invaild paramters of randomInRange";
}
else{
srand((unsigned)time(0));
return start+rand()%(end-start+1);//对数据个数求余
}
} void swap(int &a,int &b){//注意
int temp=a;
a=b;
b=temp;
} int partition(int *num,int start,int end){
if(num==nullptr||start<0||(end-start)<0){//注意end-start=0可以;书上partition加了数组长度的形参
throw "Invaild paramters of partition";//,并要限制数组的长度大于0以及end在范围内,这里未做。
}
int index=randomInRange(start, end);
swap(num[index], num[start]);
int tempElm=num[start];
int i=start;
int j=end;
while(i<j){
while(i<j&&num[j]>=tempElm){//注意>=,因为等于基准元素的元素分在它的左右两边都可以
--j;
}
if(i!=j){
num[i]=num[j];
++i;
}
while(i<j&&num[i]<=tempElm){//注意>=
++i;
}
if(i!=j){
num[j]=num[i];
--j;
}
}
num[i]=tempElm;//最后一定是I j 都指向[]的位置
return i;
} void quickSort(int *num,int start,int end){
if(start==end){return;}
int index=partition(num, start, end);
if(index>start){//注意
partition(num, start, index-1);
}
if(index<end){//注意
partition(num, index+1, end);
}
} int main(int argc, const char * argv[]) {
int num[]={3,4,5,1,1,2};
int len=sizeof(num)/sizeof(int);
quickSort(num, 0, len-1);
for(int i=0;i<len;i++){
cout<<num[i]<<" "<<endl;
}
return 0;
}

reference

https://www.zybuluo.com/Ggmatch/note/1036346

https://blog.csdn.net/yuhan_9204/article/details/46427533

[剑指Offer]快排的更多相关文章

  1. 面试题目——《剑指Offer》

    1.把一个字符串转换成整数——<剑指Offer>P29 2.求链表中的倒数第k个结点——<剑指Offer>P30 3.实现Singleton模式——<剑指Offer> ...

  2. 剑指offer习题集1

    1.打印二叉树 程序很简单,但是其中犯了一个小错误,死活找不到,写代码要注意啊 这里左右子树,要注意是node->left,结果写成root->left vector<int> ...

  3. 《剑指offer》全部题目-含Java实现

    1.二维数组中的查找 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. publi ...

  4. 剑指Offer——顺丰笔试题+知识点总结

    剑指Offer--顺丰笔试题+知识点总结 情景回顾 时间:2016.10.16 19:00-20:40 地点:山东省网络环境智能计算技术重点实验室 事件:顺丰笔试 知识点总结 快排 霍尔排序(快排) ...

  5. 剑指Offer——知识点储备-常用算法

    剑指Offer--知识点储备-常用算法 快速排序 注:若排序是有序的,采用快排,则退化为冒泡排序. 解决这个问题,采用两个选取基准的方法 (1)随机选取基数(在这个区间内随机取一个数) 出现的恶劣情况 ...

  6. 剑指Offer——好未来视频面知识点储备+面后总结

    剑指Offer--好未来视频面知识点储备+面后总结 情景介绍 时间:2016.10.12 13:00- 地点:宿舍 事件:好未来视频面 知识点储备 数据结构 单链表反转 public class Li ...

  7. 剑指Offer——CVTE校招笔试题+知识点总结(Java岗)

    剑指Offer(Java岗)--CVTE校招笔试题+知识点总结 2016.9.3 19:00参加CVTE笔试,笔试内容如下: 需要掌握的知识:Linux基本命令.网络协议.数据库.数据结构. 选择题 ...

  8. 剑指Offer——贪心算法

    剑指Offer--贪心算法 一.基本概念 所谓贪心算法是指,在对问题求解时,总是做出在当前看来是最好的选择.也就是说,不从整体最优上加以考虑,他所做出的仅是在某种意义上的局部最优解.虽然贪心算法不能对 ...

  9. Leetcode - 剑指offer 面试题29:数组中出现次数超过一半的数字及其变形(腾讯2015秋招 编程题4)

    剑指offer 面试题29:数组中出现次数超过一半的数字 提交网址: http://www.nowcoder.com/practice/e8a1b01a2df14cb2b228b30ee6a92163 ...

随机推荐

  1. 机器学习进阶-图像形态学操作-腐蚀操作 1.cv2.erode(进行腐蚀操作)

    1.cv2.erode(src, kernel, iteration) 参数说明:src表示的是输入图片,kernel表示的是方框的大小,iteration表示迭代的次数 腐蚀操作原理:存在一个ker ...

  2. WDA-6-EP系统管理/内容管理/用户管理

    主要是将EP端系统管理.内容管理.用户管理相关内容进行下梳理. 1.系统管理 1.1系统前景 1.2对象锁定 解锁相关对象 2.内容管理 2.1基本介绍 门户桌面-组件: 四大内容: iViews:可 ...

  3. Others-大数据平台Lambda架构浅析(全量计算+增量计算)

    大数据平台Lambda架构浅析(全量计算+增量计算) 2016年12月23日 22:50:53 scuter_victor 阅读数:1642 标签: spark大数据lambda 更多 个人分类: 造 ...

  4. java 实现Bridge模式(转)

    原文:http://chjking.blog.163.com/blog/static/6439511120081152534252/ 看了网上一些关于咖啡加奶的例子,觉得真是天下文章一大抄,不管好的坏 ...

  5. Oracle问题小结

    1.win8.1安装Oracle11g后,重启电脑,出现黑屏. 解决办法:安全模式下,找到以oracle开头的全部服务,所有“自动”或者“自动(延迟启动)”的都设置为“手动”,只需要开启OracleO ...

  6. centos7下找不到iptables文件

    最近在centos7下,搭建ftp服务,按照步骤一步一步来,发现 etc/sysconfig/iptables这个文件并不存在,然后去找解决方案, 原文地址:http://blog.csdn.net/ ...

  7. 计算机网络协议包头赏析-IP

    上次和大家聊了聊以太网的帧格式,本文会讲解IP数据报格式的定义. == 开门见山,先上图: 任何一个IP数据报都是由首部和数据两部分组成,而且首部基本是固定长度的,长度为20字节.这一点很重要,其他都 ...

  8. WebRequest + Https + 憑証錯誤 = 作業逾時

    前言 一般的系統一登入時,都會顯示公告訊息,我們的系統也是! 因為系統效能問題,所以就幫忙看了程式.發現,每次登入時,都會到DB取公告資料,但公告並不會因為個人而有所不同,是針對整個系統的呀! 所以就 ...

  9. Javascript中的this之我见

    来源:http://www.blogjava.net/baoyaer/articles/105864.html 在面向对象编程语言中,对于this关键字我们是非常熟悉的.比如C++.C#和Java等都 ...

  10. SQL Server 生成 数据字典 / 数据库文档

    1. 工具生成 2.SQL语句生成 参考地址:http://blog.csdn.net/qq289523052/article/details/22174721 1.在 表 上右键 - 扩展属性 - ...