SHU1952 Odd Pairs(维护前缀和)
2015-12-21 16:53
555 查看
Description
已知一个长度为N的数列A[1..N]。现在给出Q次查询,每次查询一个区间[L, R]。
对于每一个区间,求使得(A[i] + A[j])为奇数的(i, j)的对数 (L <= i < j <= R)。
Input
多组数据,第一行有一个整数T表示数据组数。(T <= 5)之后有T组数据,每组数据第一行为两个整数N和Q,表示数列长度及查询数量。
(1 <= N, Q <= 100000)
接着有一行N个元素的数列A[1..N]。(1 <= A[i] <= 1000)
接下来Q行,每行有两个整数L, R,表示查询的区间。(1 <= L <= R <= N)
Output
对于每次询问,输出一行数字,表示区间”Odd Pair”的对数。Sample Input
15 2
1 5 3 4 2
1 5
2 3
Sample Output
60
HINT
Please use printf/scanf to avoid TLE.这道题我在校OJ上是用时最短的(骄傲的)!
用到的就是维护前缀和的方法,因为两数相加要为奇数,只能是奇数加偶数的情况。
所以只要在输入数据的时候判断是奇数还是偶数,用两个个数组记录第i个为之前有几个奇数和偶数就好了,最后区间内的奇数数量和偶数数量相乘。
#include<iostream> #include<stdio.h> using namespace std; int main(void) { int t,n,q,i,a[100005],b[100005][2],l,r; long long sum1,sum2,sum3,sum4; scanf("%d",&t); while(t--) { sum1=0; sum2=0; scanf("%d%d",&n,&q); for(i=1;i<=n;i++){ scanf("%d",&a[i]); if(a[i]%2==1) sum1++; else sum2++; b[i][0]=sum1; b[i][1]=sum2; } while(q--) { scanf("%d%d",&l,&r); sum3=b[r][0]-b[l-1][0]; sum4=b[r][1]-b[l-1][1]; printf("%lld\n",sum3*sum4); } } return 0; }
相关文章推荐
- 派生类到基类的转换 和基类到派生类的转换 http://blog.csdn.net/wyyzsl212328/article/details/8263959
- 博弈算法实现简单五子棋
- MHA自动Failover过程解析(updated)(转)
- postfix mail command not found
- “Operation could not be completed. (SKErrorDomain error 0.)”
- 服务器TIME_WAIT和CLOSE_WAIT详解和解决办法
- 解决svn Authorization failed错误【SVN权限问题】
- Daily Scrum - 12/15-21
- _DllMain@12 已经在 MSVCRTD.lib(dllmain.obj) 中定义
- grails中使用quartz编写定时任务
- Kafka设计解析(三):Kafka High Availability (下)
- Leetcode: Paint House
- Scala 当用到.contains() .exists()的性能问题
- 'library cache lock' Waits: Causes and Solutions
- Jenkins进阶系列之——02email-ext邮件通知模板
- 生产者与消费者模式-阻塞 wait,notify
- Jenkins进阶系列之——01使用email-ext替换Jenkins的默认邮件通知
- 内存详解--理解 JVM 如何使用 AIX 上的本机内存
- Fix “Could not flush the DNS Resolver Cache: Function failed during execution” When Flushing DNS
- freemarker报错:Tip: If the failing expression is known to be legally null/missing, either specify a de