- 题目分析:最小生成树问题,解法采取了Kruskal算法,利用qsort和并查集实现。8.5在8.4的基础上稍作调整即可。
#include<iostream>
#include<stdlib.h>
#include<string.h>
using namespace std;
typedef struct path{
int val;
int town1,town2;
}path;
typedef path *pap;
int cmp(const void *a,const void *b){
pap p1=*(pap *)a,p2=*(pap *)b;
return p1->val - p2->val;
}
int townG[1001];
int findG(int id){
if(townG[id]<=0) return id;
else return townG[id]=findG(townG[id]);
}
void unionG(int id1,int id2){
townG[id1]+=townG[id2];
townG[id2]=id1;
}
int main()
{
int n,m;
pap P[3000];
scanf("%d %d",&n,&m);
for (int i = 0; i < m; i++){
P[i]=(pap)malloc(sizeof(path));
scanf("%d %d %d",&P[i]->town1,&P[i]->town2,&P[i]->val);
}
qsort(P,m,sizeof(pap),cmp);
memset(townG,-1,sizeof(townG));
int pi=0,cost=0,useP=0;
while (pi<m && useP!=n-1)
{
pap tmp=P[pi++];
int id1=findG(tmp->town1), id2=findG(tmp->town2);
if(id1!=-1 && id1==id2) continue;
if(townG[id1]<townG[id2]) unionG(id1,id2);
else unionG(id2,id1);
cost+=tmp->val,useP++;
}
if(useP==n-1) printf("%d",cost);
else printf("Impossible");
return 0;
}
#include<iostream>
#include<stdlib.h>
#include<string.h>
using namespace std;
typedef struct path{
int val;
int town1,town2;
int state;
}path;
typedef path *pap;
int cmp(const void *a,const void *b){
pap p1=*(pap *)a,p2=*(pap *)b;
return p1->val - p2->val;
}
int townG[101];
int findG(int id){
if(townG[id]<0) return id;
else return townG[id]=findG(townG[id]);
}
void unionG(int id1,int id2){
townG[id1]+=townG[id2];
townG[id2]=id1;
}
int pi=0,cost=0,useP=0;
int updateG(int id1,int id2);
int main()
{
int n;
pap P[5000];
scanf("%d",&n);
int pn=(n*(n-1))/2;
memset(townG,-1,sizeof(townG));
for (int i = 0; i < pn; i++){
P[i]=(pap)malloc(sizeof(path));
scanf("%d %d %d %d",&P[i]->town1,&P[i]->town2,&P[i]->val,&P[i]->state);
if(P[i]->state==1) updateG(P[i]->town1,P[i]->town2);
}
qsort(P,pn,sizeof(pap),cmp);
while (pi<pn && useP!=n-1)
{
pap tmp=P[pi++];
if(tmp->state==0)
{
int flag=updateG(tmp->town1,tmp->town2);
if(flag==1) cost+=tmp->val;
}
}
if(useP==n-1) printf("%d",cost);
else printf("Impossible");
return 0;
}
int updateG(int id1,int id2)
{
id1 = findG(id1), id2 = findG(id2);
if (id1 != -1 && id1 == id2) return 0;
useP++;
if (townG[id1] < townG[id2]) unionG(id1, id2);
else unionG(id2, id1);
return 1;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)