首页 > 其他 > 详细

Codeforces Round #374(div 2)

时间:2016-10-01 22:08:32      阅读:274      评论:0      收藏:0      [点我收藏+]

A B:0.0

C:题意:n个点m条边的DAG图(n,m<=5000),保证没有环且都连通,每个边有边权,求一条1->n的路径,使得经过的点最多,但边权和<=T(T<=10^9)

     分析:DAG图一般都能DP解决

      f[i][j]表示到了第i个点,已经经过了j个点花费的最少边权,last[i][j]就记录对应的决策

      阶段的分割就按照拓扑来,不过要注意刚开始不能只把1放进去,要把1和所有入度为0的点都放进去

             最后扫一遍答案

             值得一说的是按照题目给的边权范围,f数组是应该开long long的,但开long long会MLE,即使我把last数组人为改成动态vector,在有些点仍然会MLE

      然后我没办法了,只能改成int,然后……然后就A了……  

D、题意:有n(n<=2e5)个数,有k次操作,每次操作将一个数+x或者-x,求最后新的数组乘积和最小是多少

     分析:贪心,如果当前乘积是正数(有偶数个负数),那么就把绝对值最小的那个数加x或者减x(如果这个数是正的,就减去x,反之加x)

                      如果当前乘积是复数(有奇数个负数),同理,处理绝对值最小的那个数(如果正的就加x,反之减去x)

             要维护一个动态的数组的绝对值最小,显然维护一个priority_queue

Codeforces Round #374(div 2)

原文:http://www.cnblogs.com/wmrv587/p/5926410.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!