HDU3938 Portal 并查集

本文介绍了一种使用并查集解决图论问题的方法,通过处理边的排序及查询长度来找出任意两点间的最长边不超过给定长度的所有可能组合。
10 10 10
7 2 1
6 8 3
4 5 8
5 8 2
2 8 9
6 4 5
2 1 5
8 10 5
7 3 7
7 8 8
10 //查询长度
6
1
5
9
1
8
2
7
6
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>

using namespace std;

const int M = 10005;

/*
本题题意有必要说一下, 给出一系列查询长度, 要求你找出任意两点间的最长边小于等于给出的查询
长度, 做法是对给出的边排序,具体看代码, 我也是看了别人写的才明白题意的。
*/
struct node {

    int x;
    int y;
    int d;

}edge[M*5];

struct Node {

    int len;
    int ans;
    int id;

}query[M];

int p[M];
int sum[M];
int n, m, q;

bool cmp(node p1, node p2) {

    return p1.d < p2.d;
}

bool cmp1(Node p1, Node p2) {

    return p1.len < p2.len;
}

bool cmp2(Node p1, Node p2) {

    return p1.id < p2.id;
}

void init() {

    for(int i = 1; i <= n; i++) {

        p[i] = i;
        sum[i] = 1;
    }
}

int Find(int a) {

    return a == p[a] ? a : p[a] = Find(p[a]);
}

int Union(int a, int b) {

    a = Find(a);
    b = Find(b);
    if(a == b)
        return 0;
    else {

        p[a] = b;
        int temp = sum[a]*sum[b];
        sum[b] += sum[a];
        return temp;
    }
}

int main()
{
    while(scanf("%d%d%d", &n, &m, &q) != EOF) {

        init();
        for(int i = 0; i < m; i++) {

            scanf("%d%d%d", &edge[i].x, &edge[i].y, &edge[i].d);
        }
        for(int i = 0; i < q; i++) {

            scanf("%d", &query[i].len);
            query[i].id = i;
            query[i].ans = 0;
        }
        sort(edge, edge+ m, cmp);
        sort(query, query+q, cmp1);
        int cnt = 0;
        for(int i = 0; i < q; i++) {

            while(edge[cnt].d <= query[i].len && cnt < m) {

                query[i].ans += Union(edge[cnt].x, edge[cnt].y);
                    cnt++;
            }
            if(i > 0)
                query[i].ans += query[i-1].ans;
        }
        sort(query, query+q, cmp2);

        for(int i = 0; i < q; i++) {

            printf("%d\n", query[i].ans);
        }
    }
    return 0;
}

内容概要:本文详细介绍了基于Matlab实现的“梯级水光互补系统最大化可消纳电量期望短期优化调度模型”,属于电力系统领域高水平科研成果的复现(EI级别)。该模型聚焦于梯级水电站与光伏发电系统的协同优化调度,通过构建短期优化调度框架,旨在提升可再生能源的电量消纳能力并最大化系统综合效益。研究采用先进的数学优化方法对水光资源进行联合调度,充分考虑了光伏出力的不确定性、水资源约束、系统运行边界条件及电力平衡要求,实现了在多重约束下的电量期望最大化目标。模型不仅具备严谨的理论基础,还具有良好的工程应用前景,适用于新能源高比例渗透背景下电力系统的优化调度研究与实践。; 适合人群:具备电力系统分析、可再生能源利用或优化建模背景的研究生、科研人员及工程技术人员,特别适合致力于复现高水平学术论文(EI/顶刊)研究成果的学习者与开发者。; 使用场景及目标:① 学习并掌握梯级水电与光伏系统协同调度的建模思路与关键技术;② 熟悉基于Matlab的混合整数线性规划(MILP)或其他非线性优化方法在能源系统中的实际应用;③ 提升在新能源消纳、短期调度优化等方向的科研建模能力与代码实现水平,支持二次开发与创新研究。; 阅读建议:建议结合Matlab代码与优化理论同步研读,重点理解目标函数的设计逻辑、各类物理与运行约束的数学表达以及求解器的调用流程,推荐使用YALMIP等建模工具辅助实现,以提高模型构建效率与可读性,便于深入理解与后续拓展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值