浙大PAT 1013题 1013. Battle Over Cities

2024-02-26 22:18
文章标签 浙大 pat cities battle 1013

本文主要是介绍浙大PAT 1013题 1013. Battle Over Cities,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实质就是判断有几个联通子集,400ms的时限。可以用BFS或者DFS或者并查集,效率当然是并查集最高。

我用BFS暴力320ms过了,练习了C++ STL的QUEUE,代码如下:

#include<iostream>
#include<queue>
using namespace std;
int rel[1005][1005];
int main(){int i,j,k,N,M,K;int from,to,occ;int vst[1005];cin>>N>>M>>K;for(i=1;i<=N;i++){for(j=1;j<=N;j++){rel[i][j]=0;}	}for(i=1;i<=M;i++){cin>>from>>to;rel[from][to]=rel[to][from]=1;}for(i=1;i<=K;i++){cin>>occ;for(j=1;j<=N;j++){vst[j]=0;}vst[occ]=1;int cnt=0;		for(j=1;j<=N;j++){if(!vst[j]){vst[j]=1;cnt++;queue<int>q;q.push(j);while(!q.empty()){int tmp=q.front();  q.pop();  for(k=1;k<=N;k++){if(!vst[k]&&rel[tmp][k]){vst[k]=1;q.push(k);}}}}}cout<<cnt-1<<endl;}return 0;
}


DFS,150ms暴力通过

#include<stdio.h>
#define max_city 1005
int map[max_city][max_city],mark[max_city];
int n,m,k,repair_city,destroy_city;
void dfs(int cur){int i;for(i=1;i<=n;i++){if(map[cur][i]&&cur!=destroy_city&i!=destroy_city&&!mark[i]){mark[i]=1;dfs(i);}}
}
int main(){int i,j;int from,to,city;scanf("%d %d %d",&n,&m,&k);for(i=1;i<=n;i++){for(j=1;j<=n;j++){map[i][j]=0;}}for(i=0;i<m;i++){scanf("%d %d",&from,&to);map[from][to]=map[to][from]=1;}while(k){scanf("%d",&destroy_city);repair_city=0;for(i=1;i<=n;i++){mark[i]=0;}for(i=1;i<=n;i++){if(!mark[i]&&i!=destroy_city){repair_city++;}dfs(i);}printf("%d\n",repair_city-1);k--;}
}




而用并查集100ms通过,代码如下:

#include<stdio.h>
#define MAXN 1000
#define MAXE MAXN*(MAXN+1)/2
struct Node{int from;int to;
}node[MAXE];
int fat[MAXN],siz[MAXN];
int getfat(int x){if(fat[x]==x) return x;else return fat[x]=getfat(fat[x]);
}
void Union(int a,int b){int fa=getfat(a);int fb=getfat(b);if(fa!=fb){if(siz[fa]<=siz[fb]){fat[fa]=fb;siz[fb]+=siz[fa];}else{fat[fb]=fa;siz[fa]+=siz[fb];		}}
}
int main(){int i,j,cut;int n,m,k;scanf("%d %d %d",&n,&m,&k);for(i=0;i<m;i++){scanf("%d %d",&node[i].from,&node[i].to);}for(i=0;i<k;i++){for(j=1;j<=n;j++){fat[j]=j;siz[j]=1;}scanf("%d",&cut);for(j=0;j<m;j++){if(node[j].from==cut||node[j].to==cut) continue;if(fat[node[j].from]==fat[node[j].to]) continue;Union(node[j].from,node[j].to);}int cnt=0;for(j=1;j<=n;j++){if(j!=cut&&fat[j]==j){cnt++;			}}printf("%d\n",cnt-1);}return 0;
} 



 

这篇关于浙大PAT 1013题 1013. Battle Over Cities的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/750332

相关文章

浙大数据结构:树的定义与操作

四种遍历 #include<iostream>#include<queue>using namespace std;typedef struct treenode *BinTree;typedef BinTree position;typedef int ElementType;struct treenode{ElementType data;BinTree left;BinTre

浙大数据结构:04-树7 二叉搜索树的操作集

这道题答案都在PPT上,所以先学会再写的话并不难。 1、BinTree Insert( BinTree BST, ElementType X ) 递归实现,小就进左子树,大就进右子树。 为空就新建结点插入。 BinTree Insert( BinTree BST, ElementType X ){if(!BST){BST=(BinTree)malloc(sizeof(struct TNo

浙大数据结构:02-线性结构4 Pop Sequence

这道题我们采用数组来模拟堆栈和队列。 简单说一下大致思路,我们用栈来存1234.....,队列来存输入的一组数据,栈与队列进行匹配,相同就pop 机翻 1、条件准备 stk是栈,que是队列。 tt指向的是栈中下标,front指向队头,rear指向队尾。 初始化栈顶为0,队头为0,队尾为-1 #include<iostream>using namespace std;#defi

浙大数据结构——03-树1 树的同构

这道题我依然采用STL库的map,从而大幅减少了代码量 简单说一下思路,两棵树是否同构,只需比较俩树字母相同的结点是否同构,即是否左==左,右==右或者左==右,右==左。 1、条件准备 atree和btree是存两个数结点字母,第几个就存输入的第几个结点的字母。 map通过结点的字母作为键,从而找到两个子节点的信息 都要用char类型 #include <iostream>#inc

浙大数据结构:堆栈和队列的定义与操作

堆栈: 顺序存储: #include<stdio.h>#include<stdlib.h>typedef int ElementType ;typedef int position ;#define MAXSIZE 100#define ERROR -1struct SNode {ElementType * Data ;position top;int Maxsize;};

PAT甲级-1044 Shopping in Mars

题目   题目大意 一串项链上有n个钻石,输入给出每个钻石的价格。用m元买一个连续的项链子串(子串长度可为1),如果不能恰好花掉m元,就要找到最小的大于m的子串,如果有重复就输出多个,按递增顺序输出子串的前端和后端索引。 原来的思路 取连续的子串使和恰等于m,没有恰等于就找最小的大于。可以将子串依次累加,使得每个位置都是起始位置到该位置的序列和,整个数组显递增顺序,就可以用右边减左边

PAT (Advanced Level) Practice——1011,1012

1011:  链接: 1011 World Cup Betting - PAT (Advanced Level) Practice (pintia.cn) 题意及解题思路: 简单来说就是给你3行数字,每一行都是按照W,T,L的顺序给出相应的赔率。我们需要找到每一行的W,T,L当中最大的一个数,累乘的结果再乘以0.65,按照例子写出表达式即可。 同时还需要记录每一次选择的是W,T还是L

【Codeforces】449B Jzzhu and Cities 最短路

传送门:【Codeforces】449B Jzzhu and Cities 题目大意:一个n个节点的无向图,节点编号1~n(其中1为起点),其中有m条普通普通,还有k条从起点出发的特殊边,问最多去掉多少的特殊边使得从起点到其他所有点的最短路径的距离不变。 题目分析:这题的意图很明显啊,就是要我们去求最短路啊。那么怎么求会比较好呢?其实我们可以很容易的发现如果从起点通过边权为c的特殊

【HDU】3986 Harry Potter and the Final Battle 最短路

传送门:【HDU】3986 Harry Potter and the Final Battle 题目分析:先求一次最短路,同时记录在最短路上的顶点以及以该顶点为弧尾的最短路上的边。然后枚举删除每一条边,分别求一次最短路,其中最大的即答案。当然不可达输出-1。 测试发现堆优化的dij不如slf优化的spfa。。可能图太稀疏了吧。。。反正我觉得我写的挺搓的了。。。 代码如下:

浙大数据结构:01-复杂度2 Maximum Subsequence Sum

数据结构MOOC PTA习题 01-复杂度2 Maximum Subsequence Sum #include <iostream>using namespace std;const int M = 100005;int a[M];int main(){int k;cin >> k;int f = 1;for (int i = 0; i < k; i++){cin >> a[i