剑指offer—第二章算法之快速排序
算法:排序和查找(二分查找,归并排序,快速排序),位运算等。
查找:顺序查找,哈希查找,二叉排序树查找,哈希表。
二分查找可以解决:"旋转数组中的最小数字","数字在排序数组出现的次数"等问题。
哈希表:优点:O(1)时间内查找一个元素的效率最高。
缺点:需要额外的空间来实现哈希表。
二叉排序树查找:对应二查搜索树查找,可以解决:"二叉收索树的后续遍历","二查搜索树和双向链表"
排序:排序算法要熟练,额外空间消耗,平均时间复杂度和最差时间复杂度比较算法直接的优缺点。
快速排序:总体平均效率最好,但是并不总是,对于已排好序的数组,每一轮排序都要以最后一个做标准。时间复杂度为O(n2)
思路:关键在于在数组中选择一个数字a(随机选择),把数组中小于a的数移到a的左边,大于a的数移到a的右边。
实现函数为int partition(int a[],int length,int start,int end){如果length小于等于0或start小于等于0或end大于length或a为空。抛空异常。用int RandomInRange(int start,int end){如果end>start{srand(time(NULL)),return start+rand()%(end-start)}}随机生成函数,生成index。用void swap_element(int *a,int*b)来交换,index和end处的值。定义一个整形变量small(指向最终存放最初的index指向的枢纽值),并初始化。将index初始化并赋值为start。当index满足index<end时,if(a[index]<a[end]){++small;if(index!=small)交换index和small处得 值。并将index++。}。++small,将比枢纽值小的数都放在了此时small指针的前面,交换end和small处的值。}
partition函数可以用于解决:长队为n数组中查找第K大的数字或最小的K个数,或者数组中出现次数超过一半的数字。
实现快排的函数为 void QuickSort(int a[],int length,int start,int end){如果start==end。返回空。通过partition函数确定第一趟排序后枢纽值index的位置。if(index>start)递归调用QuickSort对左边排序。if(index<end)递归调用QuickSort对右边排序。}
#include<iostream>
using namespace std;
#include<time.h>
int RandomInRange(int start ,int end)
{
if(end>start)
{
srand(time(NULL));// srand函数是随机数发生器的初始化函数,使得随机数种子随时间的变化而变化
return start+rand() %((end-start));//产生start~end之间的随机数
}
return 0;
}
void swap_element(int *a,int *b)
{
int temp;
temp=*a;
*a=*b;
*b=temp;
} int Partition(int data[],int length,int start,int end)
{
if(data==NULL || length<=0||start<0 || end>=length)
{
cout<<"error1!"<<endl;
exit(0);
}
int index=RandomInRange(start,end); swap_element(&data[index],&data[end]);
int small=start-1;
for(index=start;index<end;index++)
{
if(data[index]<data[end])
{
++small;
if(small != index)
{
swap_element(&data[index],&data[small]);
}
}
}
++small;
swap_element(&data[small],&data[end]);
return small;
}
void Quicksort(int data[],int length,int start,int end)
{
if(start==end)
{
return ;
}
int index=Partition(data,length,start,end);
if(index>start)
Quicksort(data,length,start,index-1);
if(index<end)
Quicksort(data,length,index+1,end);
}
int main(void)
{
int data[10]={1,4,7,0,6,10,3,8,2,9};
Quicksort(data,10,0,9);
for(int i=0;i<10;i++)
cout<<data[i]<<" ";
cout<<endl;
return 0;
}
剑指offer—第二章算法之快速排序的更多相关文章
- 剑指offer—第二章算法之二分查找(旋转数组的最小值)
旋转数组的最小数字 题目:把一个数组最开始的若干元素搬到数组的末尾,我们称之为数组的旋转.输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素.例如:数组{3,4,5,1,2}为{1,2,3,4, ...
- 剑指offer第二章
剑指offer第二章 1.二维数组中的查找 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含 ...
- 剑指Offer——二分查找算法
剑指Offer--二分查找算法 前言 本片博文主要讲解查找算法的相关知识.重点介绍二分查找. 二分查找算法是在有序数组中用到的较为频繁的一种查找算法,在未接触二分查找算法时,最通用的一种做法是,对数组 ...
- 《剑指offer(第二版)》面试题55——判断是否为平衡二叉树
一.题目大意 输入一颗二叉树,判断该二叉树是否为平衡二叉树(AVL树). 二.题解 <剑指offer>上给出了两种解决方式: 1.第一种是从根节点开始,从上往下遍历每个子节点并计算以子节点 ...
- 《剑指offer 第二版》题解
剑指Offer 按题号排序 面试题 3:数组中重复的数字 面试题 4:二维数组中的查找 面试题 5:替换空格 面试题 6:从头到尾打印链表 面试题 7:重建二叉树 面试题 8:二叉树的下一个节点 面试 ...
- 经典面试题目——找到第n个丑数(参考《剑指offer(第二版)》面试题49)
一.题目大意 给你一个数n,要求返回第n个丑数.其中,丑数的定义如下: 丑数是指只包含因子2.3和5的数.(数字1也是丑数,不过是个特例)引用<剑指offer>上的话来说,对于一个数M,如 ...
- 《剑指offer(第二版)》——面试题36:二叉搜索树与双向链表
具体的题目大意和参考思路在此处不详述(见<剑指offer>),实质就是在中序遍历的过程中调整指针的指向,关于中序遍历有递归和非递归两种操作,所以此处也用了两种方法. 方法1(递归法): 代 ...
- 《剑指offer(第二版)》面试题60——n个骰子的点数
一.题目描述 把n个骰子仍在地上,所有的骰子朝上的一面的点数之和为s,输入n,打印出s所有可能的值出现的概率. 二.题解 <剑指offer>上给出的两种方法,尤其是代码,晦涩难懂且没有注释 ...
- 《剑指offer(第二版)》面试题64——求1+2+...+n
一.题目描述 求1+2+3+...+n,要求不能使用乘除法.for.while.if.else.switch.case等关键字以及条件判断语句 (即三元运算符,A? B : C) 二.题解 虽然求和问 ...
随机推荐
- 【leetcode刷题笔记】Find Minimum in Rotated Sorted Array
Suppose a sorted array is rotated at some pivot unknown to you beforehand. (i.e., 0 1 2 4 5 6 7 migh ...
- Mybatis${}、#{}及使用#{}时指定jdbcType
一.Mybatis 的Mapper.xml语句中parameterType向SQL语句传参有两种方式:#{}和${} 我们经常使用的是#{},一般解说是因为这种方式可以防止SQL注入,简单的说#{}这 ...
- git提交出现remote rejected master -> XX changes closed
问题现象: 提交git的时候出现 ! [remote rejected] master -> refs/for/master (change http://XXXX.com/myreview/c ...
- eclipse中的错误解决——The superclass "javax.servlet.http.HttpServlet" was not found on the Java Build Path
看看我们遇到的问题 解决问题
- Pandas迭代
Pandas对象之间的基本迭代的行为取决于类型.当迭代一个系列时,它被视为数组式,基本迭代产生这些值.其他数据结构,如:DataFrame和Panel,遵循类似惯例迭代对象的键. 简而言之,基本迭代( ...
- bower 安装
安装Yeomannpm install --global yo搭建一个web应用脚手架,你将需要安装generator-webapp生成器:npm install -g generator-webap ...
- linux sed使用(转)
sed入门详解教程 sed 是一个比较古老的,功能十分强大的用于文本处理的流编辑器,加上正则表达式的支持,可以进行大量的复杂的文本编辑操作.sed 本身是一个非常复杂的工具,有专门的书籍讲解 sed ...
- python脚本3_输入若干个整数打印出最大值
#输入若干个整数,打印出最大值 # m = int(input('Input first number >>>')) while True: c = input('Input a n ...
- C++(十六) — 类中引用成员函数、命名空间的使用
1.为什么类中引用成员函数? 类将属性和方法做了封装.类是一种数据类型,也就是:固定大小内存块的别名. 类的定义是一个抽象的概念,定义时不分配内存,当用类定义对象时,才分配一个固定大小的内存块. 此时 ...
- idea debug调试快捷键
F9 resume programe 恢复程序 Alt+F10 show execution point 显示执行断点 F8 Step Over ...