首页 > 代码库 > 常用算法的理解
常用算法的理解
1. 快速排序
思想: 基于分治的思想,将数组划分成两个部分,再对每个部分进行排序。
怎样做到将数组划分成两个部分呢?首先在选中一个基点,假如选择array[r](最右边元素)为基点,i和j分别从左和右向数组内部扫描,首先从左边i处开始,按照左边的元素都比基点小,右边的元素都比基点大的原则,如有违背,则调换a[i]的值和基点的值, 此时a[i]指向的是当前位置,开始移动j的位置,按照上述规则,i和j依次移动,直到a[i]和a[j]重合,此时把基准点的值放到a[i]的位置,此时基准点值所在位置就是正常排序后它所在的正确位置。完成了一次排序。
常用算法的理解
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。