ACM 吝啬的国度
发布日期:2021-09-21 12:44:41 浏览次数:6 分类:技术文章

本文共 2391 字,大约阅读时间需要 7 分钟。

吝啬的国度

时间限制:
1000 ms  |  内存限制:
65535 KB
难度:
3
描述
在一个吝啬的国度里有N个城市,这N个城市间只有N-1条路把这个N个城市连接起来。现在,Tom在第S号城市,他有张该国地图,他想知道如果自己要去参观第T号城市,必须经过的前一个城市是几号城市(假设你不走重复的路)。
输入
第一行输入一个整数M表示测试数据共有M(1<=M<=5)组
每组测试数据的第一行输入一个正整数N(1<=N<=100000)和一个正整数S(1<=S<=100000),N表示城市的总个数,S表示参观者所在城市的编号
随后的N-1行,每行有两个正整数a,b(1<=a,b<=N),表示第a号城市和第b号城市之间有一条路连通。
输出
每组测试数据输N个正整数,其中,第i个数表示从S走到i号城市,必须要经过的上一个城市的编号。(其中i=S时,请输出-1)
样例输入
110 11 91 88 1010 38 61 210 49 53 7
样例输出
-1 1 10 10 9 8 3 1 1 8

上面是题目大概意思就是一个简单的遍历 从所在城市出发下一个到达的城市的前一个城市就是所在城市   所以一次入队出队就完了

#include<cstdio>

#include<cstring>
#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<cstdlib>
#include<vector>
#include<deque>

#include<utility>

#define MAX   100020

using namespace std;

vector<int> city[MAX];//存储城市矩阵
int way[MAX];
int n, s;
int bfs()
{

#include<cstdio>
#include<cstring>
#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<cstdlib>
#include<vector>
#include<deque>
#include<utility>
#define MAX   100020
using namespace std;
vector<int> city[MAX];
int way[MAX];
int n, s;
int bfs()
{
deque<int> dq;//建立队列
dq.push_back(s);//从最开先的位置开始
while (!dq.empty())
{
int temp = dq.front();
dq.pop_front();
for (int i = 0;i < city[temp].size();i++)
{
if(way[city[temp][i]]==0)
dq.push_back(city[temp][i]);
way[city[temp][i]] = temp;
}
}
}
return 0;
}
int main(int argc, char *argv[])
{
//freopen("data.in", "r", stdin);
int M;
scanf("%d", &M);
while (M--)
{
memset(city, 0, sizeof(city));
memset(way, 0, sizeof(way));
scanf("%d%d", &n, &s);
way[s] = -1;
for(int i=1;i<n;i++)
{
int a, b;
scanf("%d%d", &a, &b);
city[a].push_back(b);
city[b].push_back(a);
}
bfs();
for(int i=1;i<n+1;i++)
{
printf("%d ", way[i]);
}
printf("\n");
}
}
写的不好见谅 

吝啬的国度

时间限制:
1000 ms  |  内存限制:
65535 KB
难度:
3
描述
在一个吝啬的国度里有N个城市,这N个城市间只有N-1条路把这个N个城市连接起来。现在,Tom在第S号城市,他有张该国地图,他想知道如果自己要去参观第T号城市,必须经过的前一个城市是几号城市(假设你不走重复的路)。
输入
第一行输入一个整数M表示测试数据共有M(1<=M<=5)组
每组测试数据的第一行输入一个正整数N(1<=N<=100000)和一个正整数S(1<=S<=100000),N表示城市的总个数,S表示参观者所在城市的编号
随后的N-1行,每行有两个正整数a,b(1<=a,b<=N),表示第a号城市和第b号城市之间有一条路连通。
输出
每组测试数据输N个正整数,其中,第i个数表示从S走到i号城市,必须要经过的上一个城市的编号。(其中i=S时,请输出-1)
样例输入
110 11 91 88 1010 38 61 210 49 53 7
样例输出
-1 1 10 10 9 8 3 1 1 8

#include<cstdio>

#include<cstring>
#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<cstdlib>
#include<vector>
#include<deque>

#include<utility>

#define MAX   100020

using namespace std;

vector<int> city[MAX];
int way[MAX];
int n, s;
int bfs()
{

转载地址:https://blog.csdn.net/Dog_dream/article/details/78730074 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:ACM 某种序列
下一篇:ACM 三水杯

发表评论

最新留言

很好
[***.229.124.182]2024年04月12日 00时53分32秒