- 博客(2)
- 收藏
- 关注
原创 C++排序方式——1 快速排序
快速排序作为一种分治算法,是为了降低算法复杂程度而生的。它的核心观念就找每个元素的正确位置。与冒泡排序每次只能进行左右交换不同,快速排序可以跳跃交换,在需要交换的时候进行交换。这个需要交换的时候是指什么呢,后面继续谈,我们需要先对快速排序建立一个整体印象。什么情况可以使用快速排序?使用快排有一个前提条件,你需要进行排序的数列应该存储于一个能得知头尾的区间,即这个序列应该具有有限性。
2023-10-08 20:02:57 36
原创 跟着代码随想录的第一天——二分查找
什么时候需要二分查找?有序数列+不重复元素+只查找一个这三个种情况一起才能去使用二分查找。什么是二分查找?不断去将一个数组分成两份,不断去比较这份数组的中位数和要查找数是否相同,直到相同为止就是二分查找。举一个现实一点的例子,你借了一堆书,里面有一本书没登记上,你现在想把它找出来,你把书平均分成两份,你把其中一份拿去过安检,你发现报警器响了,那你就把这一份书拿出来再来分成两份,再拿一份去过安检,如果响了就去拆这一份不响就去拆另外一份,不断去重复这个操作,直到只剩一本,这一本就是我们需要的。
2023-10-05 18:00:02 45
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人