常用算法的理解

Posted 果感

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了常用算法的理解相关的知识,希望对你有一定的参考价值。

1. 快速排序

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

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

 

以上是关于常用算法的理解的主要内容,如果未能解决你的问题,请参考以下文章

常用算法的理解

深入理解数据结构和算法

图解常用算法

闭关修炼中 *** Java常用算法之 -- 顺序表结构

整理一下,常用算法复杂度速查表

一些常用/经典算法的文章的收集整理