十五届山东ccpc省赛补题(update)

纯菜鸡只写出了两题,菜完了,不想当分母呀TAT

H. Minimum Spanning Tree

自己能思考到的:最小生成树的唯一性

不能思考到:只有i和i-1才有必要被新添加进去,将原本的图的边进行排序,代价为0或者1的必然不会更优了,所以能加就加,至少要加n-1-k条,若为01则加到不能加为止,先跑对有限的边一遍**克鲁斯卡尔,**然后再用最优的加边方式(i和i+1)加到整个图联通(n-1条),最后输出答案即可

上代码:

cpp 复制代码
#include<bits/stdc++.h>
#define int long long
#define fi first
#define se second
#define endl '\n'
using namespace std;
typedef pair<int,int>pii;
const int N=5e5+10;
int p[N];
struct nod{
    int u,v,w,id;
    bool operator<(const nod& b)const{
        return w<b.w;
    }
};
int find(int x){
    if(x==p[x]) return x;
    return p[x]=find(p[x]);
}
bool merge(int a,int b){
    int x=find(a),y=find(b);
    if(x==y) return 0;
    p[y]=x;
    return 1;
}
void solve(){
    int n,m,k;cin>>n>>m>>k;
    for(int i=1;i<=n;i++) p[i]=i;
    vector<nod>edg(1);
    for(int i=1;i<=m;i++){
        int u,v,w;cin>>u>>v>>w;
        edg.push_back({u,v,w,i});
    }
    sort(edg.begin()+1,edg.end());
    vector<nod>res;
    int ans=0,cnt=0;
    int must=n-1-k;
    for(int i=1;i<=m&&cnt<n-1;i++){
        auto [u,v,w,id]=edg[i];
        if(w<=1){
            if(merge(u,v)){
                cnt++;
                ans+=w;
                res.push_back(edg[i]);
            }
            continue;
        }
        if(cnt>=must){
            break;
        }
        if(merge(u,v)){
            cnt++;
            ans+=w;
            res.push_back(edg[i]);
        }
    }
    vector<nod>add;
    int idx=m+1;
    int ad=0;
    for(int i=1;i<=n-1;i++){
        if(cnt==n-1) break;
        if(ad==k) break;
        if(merge(i,i+1)){
            cnt++;
            ad++;
            ans+=1;
            add.push_back({i,i+1,1,idx});
            idx++;
        }
    }
    cout<<ad<<endl;
    for(auto [u,v,w,id]:add){
        cout<<u<<" "<<v<<endl;
    }
    cout<<ans<<endl;
    for(auto [u,v,w,id]:res){
        cout<<id<<" ";
    }
    for(auto [u,v,w,id]:add){
        cout<<id<<" ";
    }
}
signed main(){
    ios::sync_with_stdio(0);cin.tie(0);
    int T=1;cin>>T;
    while(T--){
        solve();cout<<endl;
    }
}
相关推荐
ximu_polaris1 小时前
设计模式(C++)-行为型模式-模版方法模式
c++·设计模式
AI科技星2 小时前
ELN 升级:π 级数自动生成器全域数理架构
大数据·人工智能·python·算法·金融
强盛机器学习~2 小时前
2026年SCI一区新算法-傅里叶变换优化算法(FTO)-公式原理详解与性能测评 Matlab代码免费获取
算法·matlab·进化计算·群体智能·傅里叶变换·元启发式算法
王老师青少年编程2 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【跳跃与过河问题】:过河问题
c++·算法·贪心·csp·信奥赛·跳跃与过河问题·过河问题
是个西兰花2 小时前
C++11:智能指针
开发语言·c++·智能指针·rall
CN-Dust2 小时前
【C++专题】输出cout例题
开发语言·c++
沉默-_-2 小时前
备战蓝桥杯-哈希
c++·学习·算法·蓝桥杯·哈希算法
Reese_Cool2 小时前
【STL】蓝桥杯/天梯赛终极杀器!10个C++字符串核心技巧,暴力破解高频考点
开发语言·c++·蓝桥杯·stl
拼好饭和她皆失2 小时前
基础算法--写给算法小白的模板指南:快速掌握核心代码,蓝桥杯必备模板
算法