您的位置:首页 > 其它

2016"百度之星" - 初赛(Astar Round2A)HDU 5695 拓扑排序+优先队列

2016-05-23 21:03 447 查看

Gym Class

Time Limit: 6000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 681 Accepted Submission(s): 271


[align=left]Problem Description[/align]
众所周知,度度熊喜欢各类体育活动。

今天,它终于当上了梦寐以求的体育课老师。第一次课上,它发现一个有趣的事情。在上课之前,所有同学要排成一列, 假设最开始每个人有一个唯一的ID,从1到N

,在排好队之后,每个同学会找出包括自己在内的前方所有同学的最小ID,作为自己评价这堂课的分数。麻烦的是,有一些同学不希望某个(些)同学排在他(她)前面,在满足这个前提的情况下,新晋体育课老师——度度熊,希望最后的排队结果可以使得所有同学的评价分数和最大。

[align=left]Input[/align]
第一行一个整数T

,表示T(1≤T≤30)

组数据。

对于每组数据,第一行输入两个整数N

和M(1≤N≤100000,0≤M≤100000)

,分别表示总人数和某些同学的偏好。

接下来M

行,每行两个整数A

和B(1≤A,B≤N)

,表示ID为A

的同学不希望ID为B

的同学排在他(她)之前。你可以认为题目保证至少有一种排列方法是符合所有要求的。

[align=left]Output[/align]
对于每组数据,输出最大分数 。

[align=left]Sample Input[/align]

3

1 0

2 1

1 2

3 1
3 1

[align=left]Sample Output[/align]

1

2

6

[align=left]Source[/align]
2016"百度之星" - 初赛(Astar Round2A)

题意:中文题面

题解: 拓扑排序+优先队列
两个姿势复习一遍
注意代码中标记的wa点

#include<iostream>
#include<cstring>
#include<cstdio>
#include<queue>
#include<stack>
#include<vector>
#include<map>
#define ll __int64
using namespace std;
vector<int> mp[100005];
int in[100005];
int t;
int ans[100005];
int vis[100005];
struct node
{
int x;
friend bool operator < (node aa,node bb)
{
return aa.x<bb.x;
}
};
priority_queue<node> p;
int n,m,a,b;
int main()
{
while(scanf("%d",&t)!=EOF)
{
for(int i=1;i<=t;i++)
{
scanf("%d %d",&n,&m);
int jishu=1;
struct node exm;
memset(ans,0,sizeof(ans));
for(int j=1;j<=n;j++)
{
mp[j].clear();
in[j]=0;
vis[j]=0;
}
for(int j=1;j<=m;j++)
{
scanf("%d %d",&a,&b);
mp[a].push_back(b);
in[b]++;
}
for(int j=1;j<=n;j++)
{
if(in[j]==0)
{
exm.x=j;
vis[j]=1;
p.push(exm);
}
}
while(!p.empty())
{
exm=p.top();
ans[jishu++]=exm.x;
p.pop();
for(unsigned int j=0;j<mp[exm.x].size();j++)
{
if(--in[mp[exm.x][j]]==0&&vis[mp[exm.x][j]]==0)
{
vis[mp[exm.x][j]]==1;
struct node ggggg;////wa点
ggggg.x=mp[exm.x][j];
p.push(ggggg);
}
}
}
int minx=ans[1];
ll gg=ans[1];
for(int j=2;j<=n;j++)
{
minx=min(minx,ans[j]);
gg+=minx;
}
printf("%I64d\n",gg);
}
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: