洛谷 p1137 topsort正解的证明

引自 amstar


拓扑排序,从西边往东边走,找到一个城市就让他加上“能到达他的城市”的个数;

但是我们会发现一个问题:会加重。比如题目的样例三号城市和四号城市;

怎么避免呢,我们可以只加一次,这个城市就是理他最近的城市。

我们走到了一个城市后,他所有指向的城市都会入度--,这时可以判断,如果他的入度不是0的话,说明还有城市会通向他,并且哪个城市的浏览数比当前城市的浏览数多或相等(因为他更靠后),所以我们不加;如果入度为0,那么说明没有在通向他的城市,并且当前城市的浏览数是所有能通向它的城市的最多的,我们加上他。ans数组初值为1,因为自己也是一个点。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值