风雪梦

柳絮因风起

  C++博客 :: 首页 :: 联系 :: 聚合  :: 管理
  4 Posts :: 76 Stories :: 3 Comments :: 0 Trackbacks

常用链接

留言簿

我参与的团队

搜索

  •  

最新评论

  • 1. re: LightOJ1080 Binary Simulation
  • 话说加个PushDown操作不就OK了咩?
  • --仗剑奔走天涯
  • 2. re: 正式开博
  • 加油!
  • --leafcloudsky
  • 3. re: 启航杯啊
  • 太屎了!!我竟然就这么的WA了两次,最终发现,第四题少了两句初始化,第五题把数组开错地方了,算法没问题,结果就这么从四题跌到二题,太伤不起了!!可怜我调spfa调了一晚上!!尼玛啊!!
  • --浅雨歌

阅读排行榜

评论排行榜

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1025

题意大概就是给你一大堆的城市,左边的数表示这个城市缺什么物资,右边的数表示那个物资从哪个城市往里运,两个城市之间需要链接道路,问不交叉的情况下,最多能连多少条。这道题原本应该是一个最长公共子序列,但是无奈他给的数据范围太大,LCS的做法明显不满足,所以首先我们可以把右边的数映射到左边来,这样就转化成求最长不下降子序列的问题,对于最长不下降子序列,有一种DP+二分的求法,可以在nlogn的情况下完美解决。

思路大概就是dp数组记录的是到当前长度的最靠前的元素,每遇到一个新元素,在dp数组中二分查找到小于它的最大元素的位置,在那里更新到它的最长不下降子序列,这个算法牛逼就牛逼在二分那一步了,否则也不会做到nlogn的时间复杂度

view code

posted on 2013-04-09 20:18 浅雨歌 阅读(95) 评论(0)  编辑 收藏 引用 所属分类: DP

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理