常用算法的理解

1. 快速排序

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

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

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