首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    堆排序(HeapSort)之java实现

    堆是一种重要的数据结构,为一棵完全二叉树, 底层如果用数组存储数据的话,假设某个元素为序号为i(Java数组从0开始,i为0到n-1), 如果它有左子树,那么左子树的位置是2i+1,如果有右子树,右子树的位置是2i+2,如果有父节点,父节点的位置是(n-1)/2取整。分为最大堆和最小堆,最大堆的任意子树根节点不小于任意子结点,最小堆的根节点不大于任意子结点。所谓堆排序就是利用堆这种数据结构来对数组排序,我们使用的是最大堆。处理的思想和冒泡排序,选择排序非常的类似,一层层封顶,只是最大元素的选取使用了最大堆。最大堆的最大元素一定在第0位置,构建好堆之后,交换0位置元素与顶即可。堆排序为原位排序(空间小), 且最好与最坏运行时间是都是O(nlogn)。而且堆排序还是原地算法(in-place algorithm),是渐进最优的比较排序算法。

    02

    快速排序

    快速排序与归并排序一样,也是一种分治的排序算法。与归并排序不同的是,归并排序是先使得局部有序从而整体有序,快速排序首先是整体(切分元素的位置已经确定)有序再去关心局部有序。 快速排序的主要工作都在切分这一过程中。确定一个切分元素,然后从左往右遍历找到一个比切分元素大的元素,同时从右向左遍历找到一个比切分元素小的元素,将两个数进行交换。一旦从左向右移动的坐标与从右向左移动的坐标相遇,就把切分元素放到两组数中间从而使得切分元素左边的元素不大于切分元素,切分元素右边的元素不小于切分元素。然后在切分元素左右分别递归调用切分的过程,就是整个快速排序的过程。

    03
    领券