堆排序

 1.最后一个非叶子节点的下标为:i=arr.length/2-1;例如下面左边的图

 for(int i=arr.length/2-1;i>=0;i--){
            //从第一个非叶子结点从下至上,从右至左调整结构
            adjustHeap(arr,i,arr.length);//完成后为{9,8,7,6,5,4,,3,2,1}
        }

从第一个非叶子结点从下至上,从右至左调整结构 ,例如下图,先调整非叶子节点4,i--,再调整非叶子节点3

如何调整每一个非叶子节点  arr[i]   及其对应的叶子节点,使

大顶堆:arr[i] >= arr[2i+1] && arr[i] >= arr[2i+2]  

构建大顶堆的代码:

 public static void adjustHeap(int []arr,int i,int length){
        int temp = arr[i];//先取出当前元素i
        for(int k=i*2+1;k<length;k=k*2+1){//从i结点的左子结点开始,也就是2i+1处开始
            if(k+1<length && arr[k]<arr[k+1]){//如果左子结点小于右子结点,k指向右子结点
                k++;
            }
            if(arr[k] >temp){//如果子节点大于父节点,将子节点值赋给父节点(不用进行交换)
                arr[i] = arr[k];
                i = k;
            }else{
                break;//判断与循环,break是跳出循环,即for循环
            }
        }
        arr[i] = temp;//将temp值放到最终的位置
    }

2,将堆顶元素与末尾元素进行交换,使末尾元素最大。然后继续调整堆,再将堆顶元素与末尾元素交换,得到第二大元素。如此反复进行交换、重建、交换。

注意j--,  故每次调用adjustHeap(arr,0,j);相当于把队尾元素保存起来,然后处理前面的部分,。。。。。

 //2.调整堆结构+交换堆顶元素与末尾元素
        for(int j=arr.length-1;j>0;j--){
            swap(arr,0,j);//将堆顶元素与末尾元素进行交换
            adjustHeap(arr,0,j);//重新对堆进行调整
        }

汇总代码: 

import java.util.Arrays;

public class HeapSort {
    public static void main(String[] args) {
            int arr[]={1,2,3,4,5,6,7,8,9,10,11};
        HeadSort(arr);
        System.out.println(Arrays.toString(arr));

    }

    //堆排序
    public static void HeadSort(int []arr){
        //1.构建大顶堆
        for(int i=arr.length/2-1;i>=0;i--){
            //从第一个非叶子结点从下至上,从右至左调整结构
            adjustHeap(arr,i,arr.length);
        }
        //2.调整堆结构+交换堆顶元素与末尾元素
        for(int j=arr.length-1;j>0;j--){
            swap(arr,0,j);//将堆顶元素与末尾元素进行交换
            adjustHeap(arr,0,j);//重新对堆进行调整
        }

    }

    /**
     * 调整大顶堆(仅是调整过程,建立在大顶堆已构建的基础上)
     * @param arr
     * @param i
     * @param length
     */
    public static void adjustHeap(int []arr,int i,int length){
        int temp = arr[i];//先取出当前元素i
        for(int k=i*2+1;k<length;k=k*2+1){//从i结点的左子结点开始,也就是2i+1处开始
            if(k+1<length && arr[k]<arr[k+1]){//如果左子结点小于右子结点,k指向右子结点
                k++;
            }
            if(arr[k] >temp){//如果子节点大于父节点,将子节点值赋给父节点(不用进行交换)
                arr[i] = arr[k];
                i = k;
            }else{
                break;//判断与循环,break是跳出循环,即for循环
            }
        }
        arr[i] = temp;//将temp值放到最终的位置
    }

    /**
     * 交换元素
     * @param arr
     * @param a
     * @param b
     */
    public static void swap(int []arr,int a ,int b){
        int temp=arr[a];
        arr[a] = arr[b];
        arr[b] = temp;
    }
}

参考:http://www.cnblogs.com/chengxiao/p/6129630.html

内容概要:本文围绕“基于杜鹃优化算法分时电价的综合能源系统双层协同调度研究”展开,结合Matlab代码实现,提出了一种融合杜鹃优化算法(Cuckoo Search Algorithm)与分时电价机制的综合能源系统双层协同优化调度模型。研究旨在通过需求响应机制优化能源资源配置,实现系统运行成本最小化与低碳化运行的双重目标。模型充分考虑了氢能、氨气等新型清洁能源的集成利用,体现了较强的创新性与前瞻性。研究内容涵盖综合能源系统建模、双层优化架构设计、多目标协同调度策略及智能算法求解全过程,并附有大量相关研究方向拓展,如储能选址定容、微电网调度、虚拟电厂优化、多目标智能优化算法应用等,展现出广泛的学术与工程应用价值。; 适合人群:具备电力系统、优化理论、能源管理及Matlab/Simulink编程基础的研究生、科研人员和工程技术人员,特别适合从事综合能源系统、需求响应、智能优化算法、低碳调度等方向研究的专业人士。; 使用场景及目标:① 为科研人员提供基于杜鹃优化算法的综合能源系统双层调度模型构建与仿真方法;② 探索分时电价与需求响应机制下,含氢能、氨气等新型能源的综合能源系统协同优化运行策略;③ 为解决储能配置、微电网经济调度、碳交易机制等实际工程问题提供算法支持与代码参考; 其他说明:该研究成果属于“创新未发表”类别,突出算法的原创性与实践指导意义,可通过提供的网盘链接获取完整资源,建议读者结合文中列举的多种优化算法与应用场景进行深入学习与拓展研究。
内容概要:本文档聚焦于“配电网两阶段鲁棒故障恢复研究”,通过Matlab代码实现相关算法,旨在应对配电网中突发故障后的快速、可靠恢复问题。研究采用鲁棒优化方法,有效应对可再生能源出力、负荷需求等不确定性因素,确保系统在最不利条件下仍能安全稳定运行。解决方案分为两个阶段:第一阶段为故障后的紧急响应与网络重构,核心目标是隔离故障区域并最大化重要负荷的供电恢复;第二阶段为灾后资源再调度,利用储能、可控分布式电源等进行精细化调整,以实现经济性与可靠性的最优平衡。文中提供的Matlab代码完整实现了建模、求解与仿真全过程,是对高水平学术论文的复现,兼具理论深度与实践价值。; 适合人群:具备一定电力系统基础知识和Matlab编程能力的研究生、科研人员及电力行业工程师。; 使用场景及目标:① 学习和掌握电力系统故障恢复、鲁棒优化、两阶段随机规划等高级理论与方法;② 复现顶刊论文的仿真案例,服务于自身课题研究、论文撰写或技术汇报;③ 将核心算法思想迁移应用于微电网、主动配电网等新型电力系统的优化调度项目中。; 阅读建议:此资源以Matlab代码为核心载体,因此学习者应重点研读代码结构,结合电力系统专业知识理解其背后的数学模型与物理意义。建议读者先梳理清楚“故障恢复”的整体流程,再分模块(如潮流计算、约束定义、优化求解器调用)进行代码调试与分析,通过修改参数和算例来加深理解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值