目录
堆排序
void HeapSort(vector<int>& arr)
{
//构建大顶堆,非叶子节点个数
for (int i = arr.size() / 2 - 1; i >= 0; i--)
{
//从第一个非叶子结点从下至上,从右至左调整结构
AdjustHeap(arr, i, arr.size());
}
//每次把堆顶元素与末尾元素进行交换,获取一个最大的,然后继续调整堆
for (int j = arr.size()-1; j > 0; j--)
{
SwapNum(arr, 0, j);
AdjustHeap(arr, 0, j);
}
}
void AdjustHeap(vector<int>& arr, int i, int length)
{
int temp = arr[i];//先取出当前元素i
for (int k = i * 2 + 1; k < length; k = k * 2 + 1)
{
//如果节点i的下面两个子节点中最大的比其大,则交换
//让k指向2个中最小的子节点
if (k + 1 < length && arr[k] > arr[k + 1])
k++;
//交换
if (arr[k] < temp)
{
arr[i] = arr[k];
i = k;
}
else
{
break;
}
}
arr[i] = temp;
}
void SwapNum(vector<int>& arr, int a, int b)
{
int temp = arr[a];
arr[a] = arr[b];
arr[b] = temp;
}
堆排序LeetCode题
原文链接: https://www.cnblogs.com/Fflyqaq/p/13064939.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;
也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/353846
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!