社区
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)的算法~~~
...全文
82
15
打赏
收藏
一个堆的变种问题
给一组输入数据: A 5 A 3 A 2 B 4 …… A X表示读入后面的数X,遇到B X则需要输出前面所读入的数中对X取余的结果最小的那个数,若有多个,则输出最近输入的一个。 求复杂度小于O(n^2)的算法~~~
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用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…… 会不会有点慢?
微软面试100题系列之高清完整版PDF文档[带目录+标签]by_July
数据结构是计算机科学中
一个
非常重要的概念,它涉及如何组织和存储数据以便高效地访问和修改。微软面试100题系列中的数据结构部分可能包含以下知识点: 1. **基本数据结构**:包括数组、链表、栈、队列等。 - **...
01背包
问题
的
变种
问题
(奇行种)
01背包
问题
的转化类型 文章目录01背包
问题
的转化类型[494....给你
一个
整数数组 nums 和
一个
整数 target 。 向数组中的每个整数前添加 '+' 或 '-' ,然后串联起所有整数,可以构造
一个
表达式 : 例如
DQN的几个
变种
以及各自解决的
问题
为了解决过估计
问题
,DQN提出了多个
变种
: 1. Target Network DQN原团队为了解决高估
问题
,又添加了Target Network结构。即训练两个Q网络:原有Q网络和Target Q network,原Q网络参数为 w w w,Target Q network的...
transformer论文及其
变种
transformer及其
变种
斜
堆
斜
堆
(Skew heap)也叫自适应
堆
(self-adjusting heap),它是左倾
堆
的
一个
变种
。和左倾
堆
一样,它通常也用于实现优先队列。它的合并操作的时间复杂度也是O(lg n)。 相比于左倾
堆
,斜
堆
的节点没有"零距离"这...
C++ 语言
65,186
社区成员
250,526
社区内容
发帖
与我相关
我的任务
C++ 语言
C++ 语言相关问题讨论,技术干货分享,前沿动态等
复制链接
扫一扫
分享
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++
技术论坛(原bbs)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
请不要发布与C++技术无关的贴子
请不要发布与技术无关的招聘、广告的帖子
请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下
试试用AI创作助手写篇文章吧
+ 用AI写文章