File Transfer(25 分)
2017-11-20 20:55
441 查看
05-树8 File Transfer(25 分)
We have a network of computers and a list of bi-directional connections. Each of these connections allows a file transfer from one computer to another. Is it possible to send a file from any computer on the networkto any other?
Input Specification:
Each input file contains one test case. For each test case, the first line contains N (2≤N≤104),the total number of computers in a network. Each computer in the network is then represented by a positive integer between 1 and N.
Then in the following lines, the input is given in the format:
I c1 c2
where
Istands
for inputting a connection between
c1and
c2;
or
C c1 c2
where
Cstands
for checking if it is possible to transfer files between
c1and
c2;
or
S
where
Sstands
for stopping this case.
Output Specification:
For each Ccase,
print in one line the word "yes" or "no" if it is possible or impossible to transfer files between
c1and
c2,
respectively. At the end of each case, print in one line "The network is connected." if there is a path between any pair of computers; or "There are
kcomponents."
where
kis the number of connected components
in this network.
Sample Input 1:
5
C 3 2
I 3 2
C 1 5
I 4 5
I 2 4
C 3 5
S
Sample Output 1:
no no yes There are 2 components.
Sample Input 2:
5
C 3 2
I 3 2
C 1 5
I 4 5
I 2 4
C 3 5
I 1 3
C 1 5
S
Sample Output 2:
no no yes yes The network is connected.
本题还可以做路径压缩等优化,本人并没有,请见陈 越老师详解
#include<iostream>
#include<vector>
using namespace std;
struct node{
int data;
int parent=-1;
};
int size;
int Find(vector<node> &set,int data){
int q=data-1;
while(set[q].parent>0)
q=set[q].parent;
return q;
}
void connect(vector<node> &set,int i,int j){
int m=Find(set,i);
int n=Find(set,j);
if(set[m].parent<set
.parent){
set[m].parent+=set
.parent; set
.parent=m;
}
else {set
.parent+=set[m].parent; set[m].parent=n;}
}
void query(vector<node> &set,int i,int j){
int m=Find(set,i); int n=Find(set,j);
if(m==n) cout<<"yes"<<endl;
else cout<<"no"<<endl;
}
int main(){
int i=1,j,num; cin>>size;
num=size;
vector<node> set(size);
for(int p=0;p<size;p++)
set[p].data=p+1;
string str; cin>>str;
while(str!="S"){
if(str=="C"){
cin>>i>>j;
query(set,i,j);
}
else{
cin>>i>>j;
connect(set,i,j);
num--;
}
cin>>str;
}
if(num==1)
cout<<"The network is connected."<<endl;
else
cout<<"There are "<<num<<" components."<<endl;
return 0;
}
相关文章推荐
- 05-树7. File Transfer (25)
- 05-树8 File Transfer(25 分)
- PAT 05-树7. File Transfer (25)
- 05-树7. File Transfer (25)
- PAT : 05-树7. File Transfer (25)
- 05-树8 File Transfer(25 分)
- 05-树8 File Transfer(25 分)
- 05-树8 File Transfer(25 分)
- 04-2. File Transfer (25)并查集
- 7-26 File Transfer(25 分)
- PAT 04-2. File Transfer (25) (并查集)
- 05-树8 File Transfer(25 point(s))
- [25]_arm-none-linux-gnueabi-gcc: No such file or directory
- [转]ADT中通过DDMS导入文件出错ddms transfer error: Read-only file system,Failed to push selection: Read-only file system
- Maven-008-Nexus 私服部署发布报错 Failed to deploy artifacts: Failed to transfer file: ... Return code is: 4X
- 05-树8 File Transfer
- linux 内核编译时出现scripts/sign-file.c:25:30: fatal error: openssl/opensslv.h错误的解决办法
- 通过命令行启动 Microsoft File Transfer Manager
- QA:Failed to deploy artifacts from/to snapshots XX Failed to transfer file Return code is: 405, ReasonPhrase:Method Not Allowed.
- SSH Secure File Transfer Client用public key认证登录