Agri Net POJ1258 && Constructing Roads POJ2421
题意,在给出的图中,使用最小花费的边,使这个图仍然连通。
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
const int maxn=10005;
int head[maxn];
int n,len=0,counter;
long long ans;
struct node{
int v,cost,u;
//操作符的重写默认是小于等于
bool operator < (const node& tmp) const{
return cost< tmp.cost;
}
}gra[maxn];
struct BingCha{
//并查集
int father[105];
void initial(){
//初始化不要忘记
for(int i=1;i<=n;i++){
father[i]=i;
}
}
int getfather(int v){
if(father[v]==v)return v;
return father[v]=getfather(father[v]);
//状态压缩
}
bool findtwo(int a,int b){
//看是否是同根的
return getfather(a)==getfather(b);
}
void unioned(int a,int b){
int fa=father[a],fb=father[b];
father[fa]=fb;
}
}jihe;
void addedge(int u,int v,int cost){
gra[len].u=u;
gra[len].v=v;
gra[len].cost=cost;
len++;
}
void init(){
len=0;
counter=1;ans=0;
int x;
memset(head,-1,sizeof(head));
//memset gra?
for(int i=1;i<=n;i++){//add the edges
for(int j=1;j<=n;j++){
scanf("%d",&x);
if(i<j){
addedge(i,j,x);
}
}
}
}
int main(){
while(scanf("%d",&n)!=EOF){
init();
sort(gra,gra+len);
//已经有序,那么从小值开始选边添加即可,也保证了最优结果
int idx=0;
jihe.initial();
while(counter<n || idx<len){
if(!jihe.findtwo(gra[idx].u,gra[idx].v)){
//如果不同根,就选择这条边,执行更新操作
ans+=gra[idx].cost;
counter++;
jihe.unioned(gra[idx].u,gra[idx].v);
}
idx++;
}
printf("%d\n",ans);
}
}
2421 也是裸的mst:只要把已经建了的作为输入先处理一下就好了。
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
;
int n,len,counter;
long long ans;
struct node{
int v,cost,u;
bool operator < (const node& tmp) const{
return cost< tmp.cost;
}
}gra[maxn*(maxn-)>>];
struct BingCha{
];
void initial(){
;i<=n;i++){
father[i]=i;
}
}
int getfather(int v){
if(father[v]==v)return v;
return father[v]=getfather(father[v]);
}
bool findtwo(int a,int b){
return getfather(a)==getfather(b);
}
void unioned(int a,int b){
int fa=getfather(a),fb=getfather(b);
father[fa]=fb;
}
}jihe;
void addedge(int u,int v,int cost){
gra[len].u=u;
gra[len].v=v;
gra[len].cost=cost;
len++;
}
int findxy(int x,int y){
if(x>y){int z=y;y=x;x=z;}
,id=;
;i<x;i++){
id+=j--;
}
y-=x;// here!!!
id+=y;
return id;
}
void init(){
len=;
counter=;ans=;
jihe.initial();
int x,q,y;
//memset gra?
;i<=n;i++){//add the edges
;j<=n;j++){
scanf("%d",&x);
if(i<j){
addedge(i,j,x);
}
}
}
scanf("%d",&q);
;i<=q;i++){
scanf("%d%d",&x,&y);
;
if(!jihe.findtwo(gra[idx].u,gra[idx].v)){
counter++;
jihe.unioned(gra[idx].u,gra[idx].v);
}
}
}
int main(){
while(scanf("%d",&n)!=EOF){
init();
sort(gra,gra+len);
;
while(counter<n){//|| idx<=len
if(!jihe.findtwo(gra[idx].u,gra[idx].v)){
ans+=gra[idx].cost;
counter++;
jihe.unioned(gra[idx].u,gra[idx].v);
}
idx++;
}
printf("%d\n",ans);
}
}
Agri Net POJ1258 && Constructing Roads POJ2421的更多相关文章
- HDU1102&&POJ2421 Constructing Roads 2017-04-12 19:09 44人阅读 评论(0) 收藏
Constructing Roads Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) ...
- POJ2421 Constructing Roads
Constructing Roads 这道题很水,就是一个裸的最小生成树,最不过把已经连接的节点的值再设为0. 代码: #include<cstdio> #include<cstri ...
- Constructing Roads——F
F. Constructing Roads There are N villages, which are numbered from 1 to N, and you should build som ...
- Constructing Roads In JGShining's Kingdom(HDU1025)(LCS序列的变行)
Constructing Roads In JGShining's Kingdom HDU1025 题目主要理解要用LCS进行求解! 并且一般的求法会超时!!要用二分!!! 最后蛋疼的是输出格式的注 ...
- [ACM] hdu 1025 Constructing Roads In JGShining's Kingdom (最长递增子序列,lower_bound使用)
Constructing Roads In JGShining's Kingdom Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65 ...
- HDU 1102 Constructing Roads
Constructing Roads Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- Constructing Roads (MST)
Constructing Roads Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u ...
- HDU 1025 Constructing Roads In JGShining's Kingdom(二维LIS)
Constructing Roads In JGShining's Kingdom Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65 ...
- hdu--(1025)Constructing Roads In JGShining's Kingdom(dp/LIS+二分)
Constructing Roads In JGShining's Kingdom Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65 ...
随机推荐
- struts2的知识
result的类型 转向 <result type="dispatcher"> <param name="location" > ... ...
- ubuntu修改登录信息(本机和SSH登录)
1.需要修改的主要文件和目录如下:/etc/issue/etc/motd/etc/update-motd.d//etc/issue.net 2.Ubuntu的登陆和欢迎信息控制主要在/etc/issu ...
- javascript 代码优化工具 UglifyJS
安装: 1. 安装 node.js 环境 (这个不用我教了吧,网上教程一大堆哦.) 2. 进入 https://github.com/mishoo/UglifyJS 右上角 “Download” Z ...
- HTML5 drag & drop 拖拽与拖放简介
DataTransfer 对象:退拽对象用来传递的媒介,使用一般为Event.dataTransfer. draggable 属性:就是标签元素要设置draggable=true,否则不会有效果,例如 ...
- vhost设定
vhost设定 http.conf <Directory /> AllowOverride none #Require all denied </Directory> ...
- 51nod1256乘法逆元
1256 乘法逆元 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注给出2个数M和N(M < N),且M与N互质,找出一个数K满足0 < K < ...
- 用JS写的简单轮播特效
效果如下 功能分析 1.每隔1秒换一张图片 2.鼠标移入停止切换.鼠标离开继续切换 3.鼠标移入到数字上面的时候,显示和数字对应的图片,并且停止切换,被选中的数字,背景显示橙色 4.鼠标离开数字,从该 ...
- 怎样在自己的网站上做自动生成当前url的二维码
$todoString="www.maomii.com"; generateQRfromGoogle($todoString); /** * google api 最多4296个字 ...
- Homebrew下安装Cocoapods
在Mavericks下安装Cocoapods遇到ruby安装问题,参照以下网址圆满解决问题. http://www.moncefbelyamani.com/how-to-install-xcode-h ...
- WPF中的文字修饰
我们知道,文字的修饰包括:空心字.立体字.划线字.阴影字.加粗.倾斜等.这里只说划线字的修饰方式,按划线的位置,我们可将之分为:上划线.中划线.基线与下划线.如图: 从上至下,分别为上划线(Overl ...