IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 畅通工程(kruskal做法) -> 正文阅读

[数据结构与算法]畅通工程(kruskal做法)

畅通工程(已知部分联通)

已知部分联通,不能直接用优化版的prim算法,看早期博客

//#include <bits/stdc++.h>
#include <iostream> 
#include <vector> 
#include <algorithm> 
using namespace std;
//#define int long long
const int N=1005;
struct edge{
	int u,v,f;//起点终点是否有边,权值为1 
	edge(int u,int v,int f):u(u),v(v),f(f){}
	bool operator<(const edge& n)const{
		return f>n.f;//f=1代表u、v之间已经修路,优先选 
	}
};
vector<edge> e;
int n,m;
int fa[N];
int find(int x){
	if(x==fa[x])return x;
	return fa[x]=find(fa[x]);
}
signed main(){
	ios::sync_with_stdio(false);
	cin.tie(0); 
	while(cin>>n>>m){
	if(n==0)break;
	int u,v;
	e.clear();
	for(int i=1;i<=m;i++){
		cin>>u>>v;
		e.push_back(edge(u,v,1)); 
	}
	for(int i=1;i<=n;i++){
		for(int j=i+1;j<=n;j++){
			e.push_back(edge(i,j,0));
		}
	} 
	for(int i=1;i<=n;i++)fa[i]=i;
	sort(e.begin(),e.end());
	int cnt=0;//n个顶点要收n-1条边
	int res=0;
	int s=e.size();
	for(int i=0;i<s;i++){
		if(cnt==n-1)break;
		int x=e[i].u;
		int y=e[i].v;
		int fx=find(x);
		int fy=find(y);
		if(fx!=fy){
			if(!e[i].f)res+=1;
			cnt++;
			fa[fx]=fy;
		}
	} 
	cout<<res<<endl;
	}
	return 0;
}

畅通工程再续

这道题非常奇异,每个我严谨的地方都给我带来一次wa
最后一组输入后面的空行居然非输不可
double比较大小不许用EPS

//#include <bits/stdc++.h>
#include <iostream> 
#include <stdio.h>
#include <math.h>
#include <iomanip>
#include <vector>
#include <algorithm>
using namespace std;
//#define int long long
#define EPS 1e-8
const int N=105;
int fa[N];
int find(int x){
	if(x==fa[x])return x;
	return fa[x]=find(fa[x]);
}
struct node{
	int sign,x,y;
};
int n,m;
vector<node> v;
struct edge{
	int u,v;
	double w;
	bool operator<(const edge& a){
		return w<a.w;//小于一个负数 
	}
};
vector<edge> e;
double fun(int x1,int y1,int x2,int y2){
	return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
}
signed main(){
	ios::sync_with_stdio(false);
	cin.tie(0);
	int  t;
	cin>>t;
	int x,y;
	while(t--){
		v.clear();
		e.clear();//多组输入用了容器要小心哪 
		cin>>n;
		for(int i=1;i<=n;i++){
			cin>>x>>y;
			v.push_back({i,x,y});
			fa[i]=i;
		}
		for(int i=0;i<n;i++){
			for(int j=i+1;j<n;j++){
				double len=fun(v[i].x,v[i].y,v[j].x,v[j].y);
				if(len>=10.0&&len<=1000.0){
					e.push_back({v[i].sign,v[j].sign,len});
				}
			}
		}
		sort(e.begin(),e.end());
		int cnt=0;//收齐n-1条边
		double res=0;
		int si=e.size();
		for(int i=0;i<si;i++){
			if(cnt==n-1)break;
			int x=e[i].u;
			int y=e[i].v;
			int fx=find(x);
			int fy=find(y);
			if(fx!=fy){
				cnt++;
				res+=e[i].w;
				fa[fx]=fy;
			}
		}
		if(cnt==n-1)cout<<fixed<<setprecision(1)<<res*100<<endl; 
		else cout<<"oh!"<<endl;
//		if(t)cout<<endl;
	}
	return 0;
}

不知道我EPS用错在哪儿

//#include <bits/stdc++.h>
#include <iostream> 
#include <stdio.h>
#include <math.h>
#include <iomanip>
#include <vector>
#include <algorithm>
using namespace std;
//#define int long long
#define EPS 1e-8
const int N=105;
int fa[N];
int find(int x){
	if(x==fa[x])return x;
	return fa[x]=find(fa[x]);
}
struct node{
	int sign,x,y;
};
int n,m;
vector<node> v;
struct edge{
	int u,v;
	double w;
	bool operator<(const edge& a){
		return w-a.w<-EPS;//小于一个负数 
	}
};
vector<edge> e;
double fun(int x1,int y1,int x2,int y2){
	return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
}
signed main(){
	ios::sync_with_stdio(false);
	cin.tie(0);
	int  t;
	cin>>t;
	int x,y;
	while(t--){
		v.clear();
		e.clear();//多组输入用了容器要小心哪 
		cin>>n;
		for(int i=1;i<=n;i++){
			cin>>x>>y;
			v.push_back({i,x,y});
			fa[i]=i;
		}
		for(int i=0;i<n;i++){
			for(int j=i+1;j<n;j++){
				double len=fun(v[i].x,v[i].y,v[j].x,v[j].y);
				if(len-10.0>EPS&&len-1000.0<-EPS){
					e.push_back({v[i].sign,v[j].sign,len});
				}
			}
		}
		sort(e.begin(),e.end());
		int cnt=0;//收齐n-1条边
		double res=0;
		int si=e.size();
		for(int i=0;i<si;i++){
			if(cnt==n-1)break;
			int x=e[i].u;
			int y=e[i].v;
			int fx=find(x);
			int fy=find(y);
			if(fx!=fy){
				cnt++;
				res+=e[i].w;
				fa[fx]=fy;
			}
		}
		if(cnt==n-1)cout<<fixed<<setprecision(1)<<res*100<<endl; 
		else cout<<"oh!"<<endl;
//		if(t)cout<<endl;
	}
	return 0;
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-04-24 09:40:34  更:2022-04-24 09:44:27 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 17:32:21-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码