3518. 【NOIP2013模拟11.6A组】进化序列(evolve)

(File IO): input:evolve.in output:evolve.out

Time Limits: 1000 ms Memory Limits: 262144 KB

Description

Abathur采集了一系列Primal Zerg 的基因样本,这些基因构成了一个完整的进化链。为了方便,我们用A0,A1…An-1 这n 个正整数描述它们。

一个基因Ax 可以进化为序列中在它之后的基因Ay。这个进化的复杂度,等于Ax | Ax+1…| Ay的值,其中| 是二进制或运算。

Abathur 认为复杂度小于M 的进化的被认为是温和的。它希望计算出温和的进化的对数。

Input

第一行包含两个整数n,m。

接下来一行包含A0,A1…An-1 这n 个正整数,描述这n 个基因。

Output

第一行包含一个整数,表示温和的进化的对数。

Sample Input

4 6

1 3 5 1

Sample Output

2

Data Constraint

对于30% 的数据,1 <= n <=1000。

对于100% 的数据,1 <= n<= 100000,0 <= m <= 2^30,1<= Ai<= 2^30。

题解

两种解法:

一种是类似RMQ的倍增算法

另一种是……(我也不知道,有点像单调队列……反正是队列)

我用的是第二种,虽然不知道叫什么算法,但是也讲讲

用队列que表示当前选择

a [ i ] 表示第i位的1的个数

num表示当前进化复杂度

如果当前值x,x|num>m就把队首丢掉

代码

#include<cstdio>
#include<queue>
#include<cmath>
#define lowbit(a) ((a)&-(a))
#define qu(q) ((long)log2(lowbit(q)))
#define N 32
using namespace std;
queue<long>que;
long a[N];
int main()
{ long n,m,i,q,num,x,ans=0;
freopen("evolve.in","r",stdin);
freopen("evolve.out","w",stdout);
scanf("%ld%ld",&n,&m);
num=0;
for(i=1;i<=n;i++){
scanf("%ld",&x);
while((num|x)>m){
for(q=que.front();q;q^=lowbit(q)){
a[qu(q)]--;
if(!a[qu(q)])
num^=lowbit(q);
}
que.pop();
}
num|=x;
que.push(x);
for(q=x;q;q^=lowbit(q))
a[qu(q)]++;
ans+=que.size()-1;
}
printf("%ld\n",ans);
return 0;
}

最新文章

  1. Java或Android开发中,去掉块注释格式化后每行出现的星号(*)的解决方案。(Eclipse)
  2. 软件的NABCD----安装部分
  3. Sqlite基础及其与SQLServer语法差异
  4. oschina 开发工具
  5. 【编程范式】C语言1
  6. 今日头条- iOS客户端 启动速度优化实践
  7. JDBC加载数据库驱动的方式
  8. Eclipse背景颜色改动
  9. java_web学习(六) request对象中的get和post差异
  10. scrapy_创建_调试
  11. Numpy一文全了解
  12. zabbix 应用监控作业笔记 ansible-playbook
  13. 进程间通信IPC与Binder机制原理
  14. shell中定义变量用双引号和单引号以及不用引号的区别
  15. 设计模式之模板方法模式(TemplateMethod)
  16. 给电脑插上无线网卡,变成路由器----Windows系统承载网络的使用
  17. ActiveMQ、RabbitMQ、RocketMQ、Kafka有什么优点和缺点
  18. ESXI6.0新添加硬盘未能格式化成功
  19. sql注入学习心得与sqlmap使用心得
  20. Python -- 网络编程 -- Socket简单网络通信

热门文章

  1. D. Array Splitting(后缀数组)
  2. k8s中command、args和dockerfile中的entrypoint、cmd之间的关系
  3. 如何使用css伪类,实现div左上角出现封面等提示信息
  4. python三目运算和递归的小练习
  5. 关于 Cantor 集不可数的新观点
  6. java开发环境搭建(jdk安装)和经常出现问题的探讨
  7. ReentrantLock(重入锁)的源码解析
  8. SVN 常用资源
  9. MOOC(7)- case依赖、读取json配置文件进行多个接口请求-解决用例间依赖问题(17)
  10. html中的select下拉框