ACM题目————士兵杀敌(四)
- 描述
- 
南将军麾下有百万精兵,现已知共有M个士兵,编号为1~M,每次有任务的时候,总会有一批编号连在一起人请战(编号相近的 人经常在一块,相互之间比较熟悉),最终他们获得的军功,也将会平分到每个人身上,这样,有时候,计算他们中的哪一个人到底有多少军功就是一个比较困难的 事情,军师小工的任务就是在南将军询问他某个人的军功的时候,快速的报出此人的军功,请你编写一个程序来帮助小工吧。 假设起始时所有人的军功都是0. 
- 输入
- 只有一组测试数据。
 每一行是两个整数T和M表示共有T条指令,M个士兵。(1<=T,M<=1000000)
 随后的T行,每行是一个指令。
 指令分为两种:
 一种形如
 ADD 100 500 55 表示,第100个人到第500个人请战,最终每人平均获得了55军功,每次每人获得的军功数不会超过100,不会低于-100。
 第二种形如:
 QUERY 300 表示南将军在询问第300个人的军功是多少。
- 输出
- 对于每次查询输出此人的军功,每个查询的输出占一行。
- 样例输入
- 
4 10 
 ADD 1 3 10
 QUERY 3
 ADD 2 6 50
 QUERY 3
- 样例输出
- 10
- 60
- 不得不说,树状数组真的很好用!
//Asimple
#include <stdio.h>
#include <iostream>
#include <string.h> using namespace std;
#define CLS(a) memset(a,0,sizeof(a))
const int maxn = ;
int n, T, num, cnt, point, line, x, y, t;
char str[];
int a[maxn]; int lowbit(int i)
{
return i&(-i);
} void update(int i, int v)
{
while( i > )
{
a[i] += v ;
i -= lowbit(i);
}
} int g_sum(int i)
{
int sum = ;
while( i <= n )
{
sum += a[i] ;
i += lowbit(i) ;
}
return sum ;
} int main()
{
CLS(a);
scanf("%d %d",&T,&n);
while( T -- )
{
scanf("%s",str);
if( str[] == 'A' )
{
scanf("%d %d %d",&x,&y,&num);
update(y,num);
update(x-,-num);
}
else
{
scanf("%d",&num);
printf("%d\n",g_sum(num));
}
} return ;
}
ACM题目————士兵杀敌(四)的更多相关文章
- ACM题目————士兵杀敌(三)
		[RMQ算法]:用于当数组过于庞大的时候,查询区间的最大(最小)值. 时间复杂度:O(nlogn),主要时间发费在预处理上,查询只要O(1). 描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军 ... 
- nyoj123_士兵杀敌(四)_树状数组_插线求点
		士兵杀敌(四) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 南将军麾下有百万精兵,现已知共有M个士兵,编号为1~M,每次有任务的时候,总会有一批编号连在一起人请战 ... 
- nyoj 123 士兵杀敌(四)  树状数组【单点查询+区间修改】
		士兵杀敌(四) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 南将军麾下有百万精兵,现已知共有M个士兵,编号为1~M,每次有任务的时候,总会有一批编号连在一起人请战 ... 
- nyoj123 士兵杀敌(四)树状数组 插线问点
		士兵杀敌(四) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 南将军麾下有百万精兵,现已知共有M个士兵,编号为1~M,每次有任务的时候,总会有一批编号连在一起人请战(编 ... 
- nyoj_123_士兵杀敌(四)_201404131143
		士兵杀敌(四) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 南将军麾下有百万精兵,现已知共有M个士兵,编号为1~M,每次有任务的时候,总会有一批编号连在一起人请战 ... 
- acm   士兵杀敌(一)
		士兵杀敌(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 南将军手下有N个士兵,分别编号1到N,这些士兵的杀敌数都是已知的. 小工是南将军手下的军师,南将军现在 ... 
- 南阳oj   士兵杀敌(二) 题目116 NYOJ  数据结构
		 /*士兵杀敌(二) 时间限制:1000 ms | 内存限制:65535 KB 难度:5 描写叙述 南将军手下有N个士兵.分别编号1到N.这些士兵的杀敌数都是已知的. 小工是南将军手下的军师, ... 
- NYOJ 116士兵杀敌(二) 树状数组
		题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=116 士兵杀敌(一) 数组是固定的,所以可以用一个sum数组来保存每个元素的和就行,但是不 ... 
- NYOJ 123 士兵杀敌4-树状数组的插线求点
		士兵杀敌(四) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 南将军麾下有百万精兵,现已知共有M个士兵,编号为1~M,每次有任务的时候,总会有一批编号连在一起人请战(编 ... 
随机推荐
- 各种设备的CSS3   MediaQuery整理及爽歪歪写法
			链接:http://dwz.cn/1gZQ06 ------------------------------------------------------ 备注:内容未测试过,转载的,留着备用. - ... 
- 安装confluence
			转自 王小乃 http://blog.163.com/s_w_wang/blog/static/171609221201472202759381/ 安装confluence-5.4.4-x64 参考 ... 
- C++ 基础复习 1
			1. 友元 友元的作用是,友元函数内部可以直接访问外围类的private的字段或方法.通俗的理解就是解决了访问权限的问题. 1) 有点像java的内部类,但是只能在外围类中声明,定义(实现)部分要写在 ... 
- JDK里的设计模式
			一.Creational patterns 创建模式 Abstract factory (recognizeable by creational methods returning the facto ... 
- JaveScript——简介、语法
			JS简介: 1.JavaScript是个什么东西? 它是个脚本语言,需要有宿主文件,它的宿主文件是HTML文件. 2.它与Java什么关系? 没有什么直接的联系,Java是Sun公司(已被Oracle ... 
- [原创]java WEB学习笔记50:文件上传案例
			本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ... 
- mldn android
			ed2k://|file|%E9%AD%94%E4%B9%90%E7%A7%91%E6%8A%80_Android%E5%BC%80%E5%8F%91%E5%AE%9E%E6%88%98%E7%BB% ... 
- oracle文件版本
			strings -a $AU_TOP/forms/US/GLXFCRVL.fmb|grep '$Header' 比如 strings -a /u02/CRP2/apps/apps_st/appl/a ... 
- CDC spyglass
			SoC中会有着几百的clock domains,millions的async data crossing. Glitch等cdc问题是netlist level simulation的主要目的. CD ... 
- spring的事务回滚
			@Transactional(rollbackFor = { Exception.class }) 需要把异常抛出到带有@Transactional(rollbackFor = { Exception ... 
