码迷,mamicode.com
首页 > 编程语言 > 详细

常用算法的理解

时间:2017-07-18 01:48:36      阅读:197      评论:0      收藏:0      [点我收藏+]

标签:array   扫描   部分   一个   选择   选中   常用   nbsp   依次   

1. 快速排序

思想: 基于分治的思想,将数组划分成两个部分,再对每个部分进行排序。

怎样做到将数组划分成两个部分呢?首先在选中一个基点,假如选择array[r](最右边元素)为基点,i和j分别从左和右向数组内部扫描,首先从左边i处开始,按照左边的元素都比基点小,右边的元素都比基点大的原则,如有违背,则调换a[i]的和基点的值, 此时a[i]指向的是当前位置,开始移动j的位置,按照上述规则,i和j依次移动,直到a[i]和a[j]重合,此时把基准点的值放到a[i]的位置,此时基准点值所在位置就是正常排序后它所在的正确位置。完成了一次排序。

 

常用算法的理解

标签:array   扫描   部分   一个   选择   选中   常用   nbsp   依次   

原文地址:http://www.cnblogs.com/nelson-hu/p/7198000.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!