zoukankan
html css js c++ java
Codeforces 385C Bear and Prime Numbers(素数预处理)
[Codeforces 385C Bear and Prime Numbers](http://codeforces.com/problemset/problem/385/C) 其实不是多值得记录的一道题,通过快速打素数表,再做前缀和的预处理,使查询的复杂度变为O(1)。 但是,
我在统计数组中元素出现个数时使用了map,以至于后面做前缀和的累加时,每次都要对map进行查询,以至于TLE。
而自己一直没有发现,以为是欧拉筛对于这道题还不够优,于是上网搜题解,发现别人的做法几乎一样,但是却能跑过,挣扎了许久才想起是map的原因。
map的内部实现是一颗红黑树,每次查询的复杂度为O(logN)
,在本来时间就不富裕的情况下,导致了超时。改用数组来统计后,顺利AC。做题时,在空间允许的情况下,如果每次可以确定访问的key,还是尽量用数组来做整数间的映射吧(如果每次要遍历一遍以查询,则选择map)。因为这道题纠结了许久,于是做个记录。 附上AC代码: ```C++ #include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std; typedef long long ll; typedef pair
P; typedef map
M; typedef vector
V; typedef queue
Q; const int maxn=10000000+5; int cnt[maxn]; bool is[maxn]; int prime[maxn/2]; ll sum[maxn]; void init(int mx) { int i,j,count=0; for (i=2;i<=mx;++i) { if (!is[i]) { prime[count++]=i; } for (j=0;j
>n; for (i=0;i
>m; while (m--) { int l,r; scanf("%d%d",&l,&r); l=min(maxn,l); r=min(maxn,r); printf("%d ",sum[r]-sum[l-1]); } return 0; } ```
查看全文
相关阅读:
修改VNC的分辨率
How to use WinSCP with public key authentication
CentOS-7-x86_64-DVD-1511.iso
6.828
Tampermonkey版Vimium
servlet+jsp完成简单登录
Servlet知识点小结
HTTP基础知识点小结
LeetCode 371两数之和
LeetCode53 最大子序列问题
原文地址:https://www.cnblogs.com/orangee/p/8977964.html
最新文章
Docker学习总结(14)——从代码到上线, 云端Docker化持续交付实践
Maven学习总结(25)——Eclipse Maven Update 时JDK版本变更问题
Mysql学习总结(35)——Mysql两千万数据优化及迁移
Tomcat学习总结(8)——Tomcat+Nginx集群解决均衡负载及生产环境热部署
Docker学习总结(13)——从零开始搭建Jenkins+Docker自动化集成环境
ZT 怎么样才算熟悉设计模式? [问题点数:40分,结帖人jiaoyun007]
[EffectiveC++]item35:考虑virtual函数以外的其他选择
[EffectiveC++]item34:区分接口继承和实现继承
[EffectiveC++]item33:避免遮掩继承而来的名称。
[EffectiveC++]item18:让接口容易被正确使用,不易被误用
热门文章
女软件工程师的逆袭之路 [问题点数:40分]
小提琴协奏曲《梁祝》原本是没有歌词的,后经著名词人阎肃填的词,才有了《梁祝》这首歌。
南京-重庆年底朝发夕至 南京至东北将开动车
ZT 或许你一辈子都是个小人物
ZT Android布局】在程序中设置android:gravity 和 android:layout_Gravity属性
source insight
vim
MouseGestureL.ini shift up/down/left/right edge
xv6 gdb
svn pre commit
Copyright © 2011-2022 走看看