首页 技术 正文
技术 2022年11月9日
0 收藏 904 点赞 4,867 浏览 2470 个字

★   输入文件:fans.in   输出文件:fans.out   简单对比
时间限制:1 s   内存限制:256 MB

【题目描述】

小钟、小皓和小曦都是著名偶像派OI选手,他们都有很多迷妹。

现在,有n个妹子排成了一行,从左到右编号为1到n。这些妹子中,任意一个都是其中一个人的迷妹。

现在,蒟蒻wyz有Q个问题,第i个问题为:编号在l[i]到r[i]范围内的妹子中,分别有几个小钟的迷妹、小皓的迷妹、和小曦的迷妹。

【输入格式】

输入到fans.in

第一行2个正整数n,Q。

第2行到第n+1行每行一个正整数a[i],描述了第i个妹子是谁的迷妹。a[i]=1表示小钟的迷妹,a[i]=2表示小皓的迷妹,a[i]=3表示小曦的迷妹。

第n+2行到第n+Q+1行,每行2个整数,表示第i个问题。

【输出格式】

输出到fans.out

共Q行,每行3个用空格分开的整数,分别表示对于第i个问题,有多少小钟、小皓、小曦的迷妹。

【样例输入】

6 3

2

1

1

3

2

1

1 6

3 3

2 4

【样例输出】

3 2 1

1 0 0

2 0 1

【提示】

【数据范围】

对于10%的数据,保证1<=n<=10,Q<=10,

对于25%的数据,保证1<=n<=100,Q<=100,

对于45%的数据,保证1<=n<=1000,Q<=1000,

对于100%的数据,保证1<=n<=100,000,Q<=100,000。

保证1<=a[i]<=3,1<=l[i]<=r[i]<=n。

【来源】

QBXT2017春令营第一次测试T1

屠龙宝刀点击就送

做法1

  很水的前缀和

#include <ctype.h>
#include <cstdio>void read(int &x)
{
x=;bool f=;
register char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=;
for(; isdigit(ch);ch=getchar()) x=x*+ch-'';
x=f?(~x)+:x;
}
int n,q,sum[][];
int main()
{
freopen("fans.in","r",stdin);freopen("fans.out","w",stdout);
read(n);read(q);
for(int opt,i=;i<=n;i++)
{
read(opt);
if(opt==)
{
sum[i][]=sum[i-][]+;
sum[i][]=sum[i-][];
sum[i][]=sum[i-][];
}
else if(opt==)
{
sum[i][]=sum[i-][];
sum[i][]=sum[i-][]+;
sum[i][]=sum[i-][];
}
else
{
sum[i][]=sum[i-][];
sum[i][]=sum[i-][];
sum[i][]=sum[i-][]+;
}
}
for(int x,y;q--;)
{
read(x);read(y);
printf("%d %d %d\n",sum[y][]-sum[x-][],sum[y][]-sum[x-][],sum[y][]-sum[x-][]);
}
return ;
}

改掉我前缀和的脑残求和 竟然慢了 !。。

#include <ctype.h>
#include <cstdio>
void read(int &x)
{
x=;bool f=;
register char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=;
for(; isdigit(ch);ch=getchar()) x=x*+ch-'';
x=f?(~x)+:x;
}
int n,q,sum[][];
int main()
{
freopen("fans.in","r",stdin);freopen("fans.out","w",stdout);
read(n);read(q);
for(int opt,i=;i<=n;i++)
{
read(opt);
sum[i][opt]=;
sum[i][]+=sum[i-][];
sum[i][]+=sum[i-][];
sum[i][]+=sum[i-][];
}
for(int x,y;q--;)
{
read(x);read(y);
printf("%d %d %d\n",sum[y][]-sum[x-][],sum[y][]-sum[x-][],sum[y][]-sum[x-][]);
}
return ;
}

做法2

  很水的树状数组

#include <ctype.h>
#include <cstdio>void read(int &x)
{
x=;
bool f=;
register char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=;
for(; isdigit(ch);ch=getchar()) x=x*+ch-'';
x=f?(~x)+:x;
}
int n,q;
struct bit
{
int sum[];
int lowbit(int x) {return x&((~x)+);}
int query(int x)
{
int ans=;
for(;x;x-=lowbit(x)) ans+=sum[x];
return ans;
}
void plus(int x,int y)
{
for(;x<=n;x+=lowbit(x)) sum[x]+=y;
}
}a[];
int main()
{
freopen("fans.in","r",stdin);
freopen("fans.out","w",stdout);
read(n);read(q);
for(int opt,i=;i<=n;i++)
{
scanf("%d",&opt);
a[opt].plus(i,);
}
for(int x,y;q--;)
{
read(x);read(y);
printf("%d %d %d\n",a[].query(y)-a[].query(x-),a[].query(y)-a[].query(x-),a[].query(y)-a[].query(x-));
}
return ;
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,492
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,907
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,740
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,495
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,132
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,297