博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ-3687-Labeling Balls
阅读量:6416 次
发布时间:2019-06-23

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

链接:

题意:

给n个求再个m个条件,a比b轻,找出n个求每个对应的最小重量,

同时保证1尽量小。2尽量小。。。

思路:

拓扑排序,反向建图。

刚开始正向建图没理解。

看题解才懂,题意要求1的重量尽量小,2的重量也尽量小。

所有并不是说当前判定的某几个小。

即不能按编号小的球,重量一定小来求。

所以反向建图,编号大的球重量一定大,这样跑拓扑排序就行了。

代码:

#include 
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;typedef long long LL;const int MAXN = 200 + 10;vector
G[MAXN];int in[MAXN], res[MAXN];int n, m;void Init(){ for (int i = 1;i <= n;i++) G[i].clear(); memset(in, 0, sizeof(in)); memset(res, 0, sizeof(res));}bool Tupo(){ priority_queue
que; for (int i = 1;i <= n;i++) if (in[i] == 0) que.push(i); int pos = n; while (!que.empty()) { int u = que.top(); que.pop(); res[u] = pos--; for (int i = 0;i < G[u].size();i++) { if (--in[G[u][i]] == 0) que.push(G[u][i]); } } if (pos == 0) return true; return false;}int main(){ int t; scanf("%d", &t); while (t--) { scanf("%d%d", &n, &m); Init(); int l, r; for (int i = 1;i <= m;i++) { scanf("%d%d", &l, &r); G[r].push_back(l); ++in[l]; } if (Tupo()) { printf("%d", res[1]); for (int i = 2;i <= n;i++) printf(" %d", res[i]); printf("\n"); } else printf("-1\n"); } return 0;}

  

转载于:https://www.cnblogs.com/YDDDD/p/10717264.html

你可能感兴趣的文章
阿里java面试经验大汇总(附阿里职位需求)
查看>>
Python全套零基础视频教程+软件2018最新编程视频!
查看>>
内存管理之1:x86段式内存管理与保护模式
查看>>
20180925上课截图
查看>>
IO输入/输出流的简单总结
查看>>
JavaScript之DOM-9 HTML DOM(HTML DOM概述、常用HTML DOM对象、HTML表单)
查看>>
技术成长之路(一)
查看>>
中国北方国际五金城硬件选型
查看>>
php.exe启动时提示缺少MVCR110.dall 64位 window系统 解决
查看>>
判断是否为数字方法
查看>>
[翻译] EF Core in Action 关于这本书
查看>>
js Uncaught TypeError: undefined is not a function
查看>>
[2019.2.13]BZOJ4318 OSU!
查看>>
版本号带两个小数点的,如何比较大小?( NSStringCompareOptions )
查看>>
QCustomplot使用分享(三) 图
查看>>
什么是java?
查看>>
WPF路径动画(动态逆向动画)
查看>>
Low Level Reader Protocol (LLRP) 简介
查看>>
[Micropython]TPYBoard v10x NRF24L01无线通讯模块使用教程
查看>>
mysql中show processlist过滤和杀死线程
查看>>