当前位置: 首页 > news >正文

微网站开发协议响应式网页设计图片

微网站开发协议,响应式网页设计图片,网站套站,广东网站建设价格快速排序是 Java 中 sort 函数主要的排序方法&#xff0c;所以今天要对快速排序法这种重要算法的详细原理进行分析。 思路&#xff1a;首先快速排序之所以高效一部分原因是利用了离散数学中的传递性。 例如 1 < 2 且 2 < 3 所以可以推出 1 < 3。在快速排序的过程中巧…

快速排序是 Java 中 sort 函数主要的排序方法,所以今天要对快速排序法这种重要算法的详细原理进行分析。

思路:首先快速排序之所以高效一部分原因是利用了离散数学中的传递性

例如 1 < 2 且 2 < 3 所以可以推出 1 < 3。在快速排序的过程中巧妙地使用了这个原理,所以快速排序在一般情况下效率是比其他排序高。

下面用一个示例对快速排序的运行过程进行模拟:

[4, 3, 5, 1, 2]

利用快速排序运行过程如下:

1.首先我们要设立基准,一般选择最左边的数即 temp = 4;

2. 对于 j 让其往左边移动直到遇到第一个比 temp小的数停下来。这样才能执行第3步。

3.再让 i 向右边移动直到遇到第一个比temp大的数停下来。

执行完后 i ,j 分别停留在 5,2的位置。

4.交换 i 与 j  位置所对应元素(如下图所示):

 2. 对于 j 让其往左边移动直到遇到第一个比 temp小的数停下来。

3.再让 i 向右边移动直到遇到第一个比temp大的数停下来。

上述在执行步骤 3 的时候由于 i = j 了所以不再让 i 右移动了。让 temp 与  i,j 指向的元素 交换一下即可(1与4交换位置)这样temp左边的数都比基准小,右边的数都比它大。操作完后如下所示:

以 temp 为分界线分别对左边和右边部分进行上述操作(由于分界线右边部分只有一个元素所以不必再操作):

1.首先我们要设立基准,一般选择最左边的数即 temp = 1;

2. 对于 j 让其往左边移动直到遇到第一个比 temp小的数停下来。

由于 i = j,所以严格按照规则 temp 会与temp本身交换,交换后 temp 成为了分界线,要对其左边和右边元素分别进行上述规定操作(由于temp左边没有元素所以不再操作)对分界线右边元素操作如下图所示:

1.首先我们要设立基准,一般选择最左边的数即 temp = 3;

2.对于 j 让其往左边移动直到遇到第一个比 temp小的数停下来 。

3.再让 i 向右边移动直到遇到第一个比temp大的数停下来。

由于 i = j 所以 i 不再向右移动了将 i ,j 对应元素于temp交换。得到:

left                                 right

2                                        3    

                                           i     

                                           j    

                                        temp

此时 temp为分界线,由于temp左边只有一个数,右边没有数,所以不再对分界线左右两边进行操作了。

将每一部分的运行结果拼接起来就是快速排序后的数组 [1, 2, 3, 4, 5]

需要注意的是:为什么每次都是 j 先移动,而不是i?

因为 j 的目标是找到一个比 temp 小的数,所以当 j 移动完后 j 所对应的元素大小是小于等于temp的。

i 如果再向 j 靠近的途中没有发现比temp大的数则最后会以 i = j 结束,此时 i,j所指向的元素比小于等于 temp,此时交换 i,temp 所对应元素,交换完后刚好能使temp左边不比它大,右边不比它小。

反之先移动 i 情况就相反了,不符合我们所要求的结果。 

理论成立快排代码如下:

class Solution{public void Quicksort(int a[], int left, int right) {int temp = 0;int next = 0;if(left >= right) return;//退出条件temp = a[left];int i = left;int j = right;while(i != j) {//结束循环条件while(i < j && a[j] >= temp) j --;//找到比temp小的数while(i < j && a[i] <= temp) i ++;//找比temp大的数if(i == j) {next = a[left];a[left] = a[i];a[i] = next;}//与基准交换else {next = a[i];a[i] = a[j];a[j] = next;}//i,j交换}//i,j为分界线Quicksort(a, left, i - 1);//递归分界线左边Quicksort(a, i + 1, right);//递归分解线右边}
}

对几种特殊情况的解释:当 j 向左移动时没有找到比 temp 小的数,最后会以 i = j 收尾,此种情况说明 temp 已经是最小的数了,而且 temp 就在最左侧,对 temp 右边数进行后续快排操作完全没问题。

当 j 找到比 temp 大的数,i 向右移动的过程中没有找到比 temp 大的数,最后也会以 i = j 收尾。此种情况说明 i 和 j 左边元素都不比 temp 大,右边元素都不比temp小此时 i,j 所对应元素是比temp 小的,然后交换temp 与 i ,j 所对应元素刚好使得交换后temp左边元素不比temp大,右边元素不比temp小。

http://www.yayakq.cn/news/653722/

相关文章:

  • 网站的前台乐清网站制作公司有哪些
  • 联想粒子云可以做网站ui设计主要包括什么
  • 个人网站营业执照互联网备案服务平台
  • 商城网站 没有什么文章 怎样优化安徽建设银行官方网站
  • 中国铁塔公司招聘网站做网站专题的效果
  • 网站怎么提升关键词排名太湖网站建设
  • 手表网站背景新乡网站建设费用
  • 仙桃哪里做网站广州建网站自助建站系统
  • 南京做网站开发 待遇wordpress 密码看贴
  • 网站备案信息保护网站pc转移动端代码
  • 做渔家乐哪个网站最好dede5.7微电影网站模板
  • 汽配人网做网站自己制作的网站怎么发布
  • 网站编程开发外贸服装网站模板
  • 重庆企业网站推广价格注册地址和办公地址
  • 影响网站收录的因数男女做那个全面视频网站
  • 可以搜任何网站的浏览器中迅做网站是模板站吗
  • 罗湖装修公司网站建设订货网站怎么做
  • 公司网站怎么设计自建服务器做网站要备案
  • 东莞网站建设最牛wordpress 验证百度网盟
  • 新浪云计算 网站开发wordpress怎么发布文章带图片
  • 成都行业网站设计品牌营销策划方案模板
  • 淮安市哪里可以做网站wordpress编辑空两格
  • 毕业设计可以做网站不厅门户网站建设
  • 网站建设基本步骤是什么哪里可以做营销型网站
  • 中国设计之窗官方网站如何查询网站的访问量
  • 怎么创建教育网站泌阳县住房建设局网站
  • 企业网站建设熊掌号网站模板二次开发
  • seo 网站优化网站制作软件名字线做
  • 哈尔滨模板建站服务商网站正在建设中 英文
  • 高中生做网站网页wordpress价钱