社区
C++ 语言
帖子详情
一个堆的变种问题
wjg945
2011-05-11 12:03:01
给一组输入数据:
A 5
A 3
A 2
B 4
……
A X表示读入后面的数X,遇到B X则需要输出前面所读入的数中对X取余的结果最小的那个数,若有多个,则输出最近输入的一个。
求复杂度小于O(n^2)的算法~~~
...全文
76
15
打赏
收藏
一个堆的变种问题
给一组输入数据: A 5 A 3 A 2 B 4 …… A X表示读入后面的数X,遇到B X则需要输出前面所读入的数中对X取余的结果最小的那个数,若有多个,则输出最近输入的一个。 求复杂度小于O(n^2)的算法~~~
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
15 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
qq120848369
2011-05-11
打赏
举报
回复
[Quote=引用 2 楼 wjg945 的回复:]
引用 1 楼 qq120848369 的回复:
C/C++ code
是A就存起来,是B就算一遍.
这个就O(n^2)复杂度了,这个题的数据有100000,必然要超时啊~~
[/Quote]
是A的就存储到map里,遇到B X的时候,如果map[0]小于X,那么就是map[0]。如果map[0]==X,那么就是0.
否则呢,就不一定了,此时把map按遍历顺序(begin(),end())拷贝到一个vector里,使用lower_bound去找X,2*X,3*X...
比如lower_bound(X),那么如果存在肯定会返回大于等于X的余数最小的。
wjg945
2011-05-11
打赏
举报
回复
[Quote=引用 1 楼 qq120848369 的回复:]
C/C++ code
是A就存起来,是B就算一遍.
[/Quote]
这个就O(n^2)复杂度了,这个题的数据有100000,必然要超时啊~~
qq120848369
2011-05-11
打赏
举报
回复
是A就存起来,是B就算一遍.
wjg945
2011-05-11
打赏
举报
回复
[Quote=引用 14 楼 qq120848369 的回复:]
引用 13 楼 wjg945 的回复:
恩,这样优化,这个方法差不多比较完善了。
合作得到了一个不错的方案,我提出了用X,2*X,3*X压缩搜索空间,你提出了一个非常典型的反例,带给了进一步改进的思路,很和谐很有爱,分一定要都给我。
[/Quote]
呵呵,总共就我们两个人,分不给你还能给谁啊~~
qq120848369
2011-05-11
打赏
举报
回复
[Quote=引用 13 楼 wjg945 的回复:]
恩,这样优化,这个方法差不多比较完善了。
[/Quote]
合作得到了一个不错的方案,我提出了用X,2*X,3*X压缩搜索空间,你提出了一个非常典型的反例,带给了进一步改进的思路,很和谐很有爱,分一定要都给我。
wjg945
2011-05-11
打赏
举报
回复
恩,这样优化,这个方法差不多比较完善了。
qq120848369
2011-05-11
打赏
举报
回复
这样,先lower_bound(1*X),找到了数字N,求一次余数。 然后,如果2*X比N小,就看3*X是否比N小,一直到k*X比N大,那么可以再次调用lower_bound(k*X)得到N1,并且计算一次余数。 然后再看(k+1)*X是否大于N1。。。。
如此如此,又压缩了搜索空间。
wjg945
2011-05-11
打赏
举报
回复
校赛的时候想了半天也没思绪,100来人中只有几个过了,还是有点难度~
qq120848369
2011-05-11
打赏
举报
回复
[Quote=引用 9 楼 wjg945 的回复:]
引用 8 楼 qq120848369 的回复:
不用map[0]那些判断了,直接拷贝到vector里,调用若干次,取lower_bound其中余数最小的。。
最多是nlgn的复杂度,因为搜索空间变成了比X,2*X,3*X大的第一个数,而不是所有的数都算一遍。
如果输入数据是
A 100000
A 99999
A 99998
B 2
那么就要找比 1*2,2*2,3*2……
[/Quote]
++,一起思考一下。
wjg945
2011-05-11
打赏
举报
回复
[Quote=引用 8 楼 qq120848369 的回复:]
不用map[0]那些判断了,直接拷贝到vector里,调用若干次,取lower_bound其中余数最小的。。
最多是nlgn的复杂度,因为搜索空间变成了比X,2*X,3*X大的第一个数,而不是所有的数都算一遍。
[/Quote]
如果输入数据是
A 100000
A 99999
A 99998
B 2
那么就要找比 1*2,2*2,3*2,……,50000*2大的第一个数,这就需要操作50000次了,不是lgn了
qq120848369
2011-05-11
打赏
举报
回复
不用map[0]那些判断了,直接拷贝到vector里,调用若干次lower_bound,取其中余数最小的。。
最多是nlgn的复杂度,因为搜索空间变成了比X,2*X,3*X大的第一个数,而不是所有的数都算一遍。
qq120848369
2011-05-11
打赏
举报
回复
我想错了。。。咋给想成数最小了,乱了。
qq120848369
2011-05-11
打赏
举报
回复
[Quote=引用 4 楼 wjg945 的回复:]
引用 3 楼 qq120848369 的回复:
使用lower_bound去找X,2*X,3*X
C/C++ code
这一步的复杂度是不是有点高了?原题里面可能有很多组B X,每次都要找X,2*X,3*X…… 会不会有点慢?
[/Quote]
还行吧,一旦2*X在lower_bound时返回end(),那么后边的就不用试了。
wjg945
2011-05-11
打赏
举报
回复
求高手指教~~
wjg945
2011-05-11
打赏
举报
回复
[Quote=引用 3 楼 qq120848369 的回复:]
使用lower_bound去找X,2*X,3*X
C/C++ code
[/Quote]
这一步的复杂度是不是有点高了?原题里面可能有很多组B X,每次都要找X,2*X,3*X…… 会不会有点慢?
DQN的几个
变种
以及各自解决的
问题
为了解决过估计
问题
,DQN提出了多个
变种
: 1. Target Network DQN原团队为了解决高估
问题
,又添加了Target Network结构。即训练两个Q网络:原有Q网络和Target Q network,原Q网络参数为 w w w,Target Q network的...
transformer论文及其
变种
transformer及其
变种
尼姆游戏(聪明版)python
拿走最后
一个
物品的玩家输掉游戏在聪明模式中,计算机每次拿走足够多的物品使得
堆
的大小是2 的幂次方减1——也就是3,7,15,31 或63。除了
堆
的大小已经是2 的幂次方减1,在其他情况下这样走都是符合游戏规则的。在那种...
斜
堆
斜
堆
(Skew heap)也叫自适应
堆
(self-adjusting heap),它是左倾
堆
的
一个
变种
。和左倾
堆
一样,它通常也用于实现优先队列。它的合并操作的时间复杂度也是O(lg n)。 相比于左倾
堆
,斜
堆
的节点没有"零距离"这...
学习笔记 | 详解TopK
问题
详解 TopK 01 TopK
问题
...如下图所示,首先取前 K 个元素建立
一个
大根
堆
,然后对剩下的 N-K 个元素进行遍历,如果小于
堆
顶的元素,则替换掉
堆
顶元素,然后调整
堆
。当全部遍历完成时,
堆
中的 K 个元素就是最小
C++ 语言
64,650
社区成员
250,477
社区内容
发帖
与我相关
我的任务
C++ 语言
C++ 语言相关问题讨论,技术干货分享,前沿动态等
复制链接
扫一扫
分享
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++
技术论坛(原bbs)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
请不要发布与C++技术无关的贴子
请不要发布与技术无关的招聘、广告的帖子
请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下
试试用AI创作助手写篇文章吧
+ 用AI写文章