博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu1166 敌兵布阵
阅读量:5093 次
发布时间:2019-06-13

本文共 1321 字,大约阅读时间需要 4 分钟。

似乎当初就是学到这里然后自己就去乱搞了?然后就弃坑了?想想挺难受的其实

 

 

树状数组板子题。初始化wa了一发

1 #include
2 #include
3 #include
4 #include
5 #include
6 #include
7 #include
8 using namespace std; 9 #define mem(a,b) memset(a,b,sizeof(a))10 #define ll long long11 #define inf 100000000012 #define maxn 4000013 #define eps 1e-1214 #define mod 100000000715 inline int read()16 {17 int x=0,f=1;char ch=getchar();18 while(ch<'0'||ch>'9') { if(ch=='-') f=-1;ch=getchar();}19 while(ch>='0'&&ch<='9') {x=10*x+ch-'0';ch=getchar();}20 return x*f;21 }22 int a[50005],n;23 char s[20];24 int lowbit(int i)25 {26 return i&(-i);27 }28 void update(int i,int peo)29 {30 while(i<=n)31 {32 a[i]+=peo;i+=lowbit(i);33 }34 }35 int sum(int i)36 {37 int sum=0;38 while(i>0)39 {40 sum+=a[i];41 i-=lowbit(i);42 }43 return sum;44 }45 int main()46 {47 int T;48 T=read();49 int num=1,peo;50 while(T--)51 {52 n=read();53 mem(a,0);54 for(int i=1;i<=n;++i) peo=read(),update(i,peo);55 printf("Case %d:\n",num++);56 while(scanf("%s",s))57 {58 if(s[0]=='E') break;59 int x,y;60 x=read();y=read();61 if(s[0]=='Q') printf("%d\n",sum(y)-sum(x-1));62 else if(s[0]=='A') update(x,y);63 else update(x,-y);64 }65 }66 return 0;67 }

 

转载于:https://www.cnblogs.com/TYH-TYH/p/8903854.html

你可能感兴趣的文章
【传道】中国首部淘宝卖家演讲公开课:农业本该如此
查看>>
jQuery应用 代码片段
查看>>
MVC+Servlet+mysql+jsp读取数据库信息
查看>>
黑马程序员——2 注释
查看>>
用OGRE1.74搭建游戏框架(三)--加入人物控制和场景
查看>>
转化课-计算机基础及上网过程
查看>>
android dialog使用自定义布局 设置窗体大小位置
查看>>
ionic2+ 基础
查看>>
互联网模式下我们更加应该“专注”
查看>>
myeclipse集成jdk、tomcat8、maven、svn
查看>>
查询消除重复行
查看>>
Win 10 文件浏览器无法打开
查看>>
[leetcode]Minimum Path Sum
查看>>
内存管理 浅析 内存管理/内存优化技巧
查看>>
【BZOJ 5222】[Lydsy2017省队十连测]怪题
查看>>
Java跟Javac,package与import
查看>>
day-12 python实现简单线性回归和多元线性回归算法
查看>>
Json格式的字符串转换为正常显示的日期格式
查看>>
[转]使用 Razor 进行递归操作
查看>>
[转]Android xxx is not translated in yyy, zzz 的解决方法
查看>>