leetcode 135.Candy

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/ljhandlwt/article/details/52693647

拓扑排序


题意:

一排小朋友,每个小朋友有一个权值,你要给小朋友发糖,有两个规则.

1.每个小朋友至少有一颗糖

2.如果某个小朋友A的权值比它旁边的小朋友B大,那么A分得的糖应该比B要多.


思路:

思想是拓扑排序+dp.

建一个有向图,对于相邻的A和B,如果A的权值比B大,则B向A建一条边.

建好后,这个图肯定是DAG,然后用类似拓扑排序的顺序对这个DAG进行dp,dp[i]=max(dp[son])+1.

实际上不用建图,直接dp,复杂度O(n).


总结:

建一个DAG,在上面拓扑排序地dp.


阅读更多
想对作者说点什么?

博主推荐

换一批

没有更多推荐了,返回首页