您的位置:首页 > 其它

HDU 4737 A Bit Fun 水暴力

2016-09-14 20:55 344 查看
  题意:

          给出了一列数..定义f(i,j)为第i个数开始一次做或运算到最后一个数..问比给定的m小的f(i,j)有多少对...

数据不是很大 暴力可以过

ACcode:

#include <bits/stdc++.h>
#define maxn 100005
int a[maxn];
int main(){
int loop,cnt=1,n,m,ans;
scanf("%d",&loop);
while(loop--){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;++i)scanf("%d",&a[i]);
ans=0;
for(int i=1;i<=n;++i){
int tmp=a[i];
if(tmp<m)ans++;
for(int j=i+1;j<=n;++j){
tmp|=a[j];
if(tmp<m)
ans++;
else break;
}
}
printf("Case #%d: %d\n",cnt++,ans);
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: