河南省多校连萌(三)【B-Bar ABCDEFGH 问题 E: QAQ & 君临天下 || 天行九歌】

点击打开链接


问题 E: QAQ & 君临天下 || 天行九歌

时间限制: 1 Sec  内存限制: 128 MB

提交: 730  解决: 222

题目描述

QAQ~生活之余喜欢看一些动漫,说到国产动漫,QAQ 最喜欢的就属玄机了,玄机出品的动漫都很赞的说,君临天下 和 天行九歌是 QAQ 最喜欢的两部动漫了,每次看完 QAQ 对玄机的敬佩值都会分别增加 2 与 1,QAQ 记录了自己每天看的动漫名称 由 A ~ Z 26个字母代替,J:代表 君临天下,T 代表 : 天行九歌。

有一天,ORZ 突发奇想想帮 QAQ 测试一下 L ~ R 天里 QAQ 对玄机的敬佩值增加了多少,看 QAQ 能否清楚记得?

问题来了 ORZ 怎么知道 QAQ 回答的对错呢 ?所以 ORZ 想请你帮忙算出 L ~ R 天里 QAQ 对玄机的敬佩值增加的正确答案。

输入

第一行一个 T ( $1 \leq T \leq 10$)代表有 T 组测试数据

第二行两个数 n ,m ($1 \leq n,m \leq 10^5$),分别代表看了 n 天动漫,和 m 次查询

接下来 n 行一个 A ~ Z 的字母,表示第 i 天看的动漫名称

接下来 m 行,每行两个数 L,R ($1 \leq L \leq R \leq n$)

输出

对于每次查询,输出 L~R 天里,QAQ对玄机的敬佩值增加了多少

样例输入

1
3 3
J
A
T
1 1
1 2
2 3

样例输出

2
2
1




#include<cstdio>
#include<algorithm>
#include<iostream>
using namespace std;

int t,n,m,f[100005];

int main()
{
	while(~scanf("%d",&t)){
		while(t--){
			f[0]=0;
			scanf("%d%d",&n,&m);
			for(int i=1;i<=n;i++)
			{
				char a;
				cin>>a;
				if(a=='J') f[i]=f[i-1]+2;
				else if(a=='T') f[i]=f[i-1]+1;
				else f[i]=f[i-1];
			}
			int l,r;
			for(int i=1;i<=m;i++){
				scanf("%d%d",&l,&r);
				printf("%d\n",f[r]-f[l-1]);
			}
		}
	}
	return 0;
}





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值