2442. Sequence (POJ)

8 篇文章 0 订阅

题意理解

给定m×n矩阵,一次从每行各取一个数,加起来计算总和,一共有n×m个和,求前n小和的序列。m<500,n<2000

问题分析

用堆数据结构+贪心算法

直接计算m×n个和再排序显得笨。参考网上的思路,对矩阵每行从小到大排序,当m=1时,前n个和等于第一行元素;设m=k时,前k行的前n小和已知。那么当m=k+1时,前k+1的前n小和是,前n小和与k+1行元素逐个相加得到。从左到右依次相加,可以得到,如果某个和超过了前n小和的最大值,那么后面的情况就不用处理了。这里涉及到一个重复操作,每次从前n小和中找到最大那个和,然后替换它。这是用堆的地方。

时间优化

性能优化点1:一次性读入m×n然后逐行拷贝效率低,换成,依次读入一行,原地排序比较高

性能优化点2:遍历前n小和和k+1行的和时,对于超过前n小和最大值出现时就退出遍历。减少无效比较

其他

此题参考网上的,学习了。堆的一个妙用,是一次可以给出一个最大值或是最小值。

用到<algorithm>中的make_heap,pop_heap,push_heap,sort_heap。

对于需要使用break跳出循环的场景,可以将跳出判断放到for循环第二层来实现。

堆是个好东西,有机会再练几题。

代码链接

https://github.com/xierensong/learngit/blob/master/poj/p2442.cpp

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值