http://acm.nyist.net/JudgeOnline/problem.php?pid=20
吝啬的国度
时间限制:
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) 样例输入
-
1 10 1 1 9 1 8 8 10 10 3 8 6 1 2 10 4 9 5 3 7
样例输出
-
-1 1 10 10 9 8 3 1 1 8
-
第一行输入一个整数M表示测试数据共有M(1<=M<=5)组
#include<stdio.h>
#include<string.h>
#include<malloc.h>
#include<queue>
#include<algorithm>
using namespace std;
const int NUM=100000+10;
struct Node
{
int n;
struct Node *next;
} *p,*q;
struct City
{
bool judge;
int n;
struct Node *next;
}num[NUM];
int n,m,city[NUM];
void BFS(struct Node *s)
{
int i,k;
queue<int>Q;
for(;s;s=s->next)
{
Q.push(s->n);
city[s->n]=m;
}
while(!Q.empty())
{
k=Q.front();
Q.pop();
num[k].judge=true;
for(q=num[k].next;q;q=q->next)
{
if(!num[q->n].judge)
{
Q.push(q->n);
city[q->n]=k;
}
}
}
}
int main()
{
int N,i,j,a,b;
scanf("%d",&N);
while(N--)
{
scanf("%d %d",&n,&m);
for(i=1;i<=n;i++)
{
num[i].judge=false;
num[i].n=i;
num[i].next=NULL;
}
for(i=0;i<n-1;i++)
{
scanf("%d %d",&a,&b);
p=(struct Node *)malloc(sizeof(struct Node));
p->n=b;
p->next=num[a].next;
num[a].next=p;
q=(struct Node *)malloc(sizeof(struct Node));
q->n=a;
q->next=num[b].next;
num[b].next=q;
}
num[m].judge=true;
memset(city,0,sizeof(city));
city[m]=-1;
BFS(num[m].next);
for(i=1;i<=n;i++)
{
printf("%d",city[i]);
if(i!=n)
printf(" ");
else
printf("\n");
}
}
return 0;
}

本文深入探讨了信息技术领域的多个细分技术领域,包括前端开发、后端开发、移动开发、游戏开发等,提供了关于大数据开发、开发工具、嵌入式硬件、嵌入式电路知识、嵌入式开发环境、音视频基础、音视频直播流媒体、图像处理AR特效、AI音视频处理、测试、基础运维、DevOps、操作系统、云计算厂商、自然语言处理、区块链、隐私计算、文档协作与知识管理、版本控制、项目管理与协作工具、有监督学习、无监督学习、半监督学习、强化学习、数据安全、数据挖掘、数据结构、算法、非IT技术、自动推理、人工神经网络与计算、自动驾驶、数据分析、数据工程、程序设计方法、数据库理论、代码管理工具等主题的详细解析。
&spm=1001.2101.3001.5002&articleId=45114323&d=1&t=3&u=699c49e562184c7ab6d1fe4f99544bff)
452

被折叠的 条评论
为什么被折叠?



