Eugeny and Array(水题,注意题目描述即可)

Eugeny has array a = a1, a2, ..., an, consisting of n integers. Each integer ai equals to -1, or to 1. Also, he has m queries:

  • Query number i is given as a pair of integers liri (1 ≤ li ≤ ri ≤ n).
  • The response to the query will be integer 1, if the elements of array a can be rearranged so as the sum ali + ali + 1 + ... + ari = 0, otherwise the response to the query will be integer 0.

Help Eugeny, answer all his queries.

Input

The first line contains integers n and m (1 ≤ n, m ≤ 2·105). The second line contains n integers a1, a2, ..., an (ai = -1, 1). Next m lines contain Eugene's queries. The i-th line contains integers li, ri (1 ≤ li ≤ ri ≤ n).

Output

Print m integers — the responses to Eugene's queries in the order they occur in the input.

Examples

Input

2 3
1 -1
1 1
1 2
2 2

Output

0
1
0

Input

5 5
-1 1 1 1 -1
1 1
2 3
3 5
2 5
1 5

Output

0
1
0
1
0

代码

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>


using namespace std;

int main() {
	int n,m;
	int num[200005];
	cin>>n>>m;
	int sum1=0,sum2=0;
	for(int t=0; t<n; t++) {
		scanf("%d",&num[t]);
		if(num[t]==-1) {
			sum1++;
		} else {
			sum2++;
		}
	}
	int l,r;
	for(int t=0; t<m; t++) {
		scanf("%d%d",&l,&r);
		if((r-l)%2==0)
			printf("0\n");
		else if((r-l)%2!=0) {
			if((r-l+1)/2<=sum1&&(r-l+1)/2<=sum2)
				printf("1\n");
			else
				printf("0\n");
		}
	}



	return 0;
}

 

posted @   black_hole6  阅读(135)  评论(0编辑  收藏  举报
编辑推荐:
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
阅读排行:
· Windows桌面应用自动更新解决方案SharpUpdater5发布
· 我的家庭实验室服务器集群硬件清单
· C# 13 中的新增功能实操
· Supergateway:MCP服务器的远程调试与集成工具
· Vue3封装支持Base64导出的电子签名组件
欢迎阅读『Eugeny and Array(水题,注意题目描述即可)』
点击右上角即可分享
微信分享提示