JZOJ 100047. 【NOIP2017提高A组模拟7.14】基因变异
来源:互联网 发布:适合学生的网络兼职 编辑:程序博客网 时间:2024/05/17 07:31
Description
21 世纪是生物学的世纪,以遗传与进化为代表的现代生物理论越来越多的 进入了我们的视野。 如同大家所熟知的,基因是遗传因子,它记录了生命的基本构造和性能。 因此生物进化与基因的变异息息相关,考察基因变异的途径对研究生物学有着 至关重要的作用。现在,让我们来看这样一个模型:
1、所有的基因都可以看作一个整数或该整数对应的二进制码;
2、在 1 单位时间内,基因 x 可能会在其某一个二进制位上发生反转;
3、在 1 单位时间内,基因 x 可能会遭到可感染基因库内任一基因 y 的影响 而突变为 x XOR y。
现在给出可感染基因库,Q 组询问,每组给出初始基因与终止基因,请你 分别计算出每种变异最少要花费多少个单位时间。
Input
第 1 行两个整数 N, Q; 第 2 行 N 个用空格隔开的整数分别表示可感染基因库内的基因; 接下来 Q 行每行两个整数 S、T,分别表示初始基因与终止基因。
Output
输出 Q 行,依次表示每组初始基因到终止基因间最少所花时间。
Sample Input
3 3
1 2 3
3 4
1 2
3 9
Sample Output
2
1
2
Data Constraint
对于 20%的数据,N = 0;
对于额外 40%的数据,1 ≤ Q ≤ 100,所有基因表示为不超过 10^4 的非负整 数;
对于 100%的数据,0 ≤ N ≤ 20,1 ≤ Q ≤ 10^5,所有基因表示为不超过 10^6 的 非负整数。
Solution
题目给出若干个询问
x,y ,问x 变成y 的最小变换次数。变换有两种:与给定的数异或 和 将自身某个二进制位取反 。
可以发现,后者相当于与 2 的幂数 (二进制为 1后面全0)异或。
又可以发现,令
z=x xor y ,则z 的二进制中1 的个数即为x 与y 之间的“差异”。所以从
0 转化成z 的最小变换次数是等价于所求的答案的。由于初始状态只是
0 (单源),我们就以其为起点做一次 BFS (不断异或),预处理出转移到任意值的最小步数,读入时直接输出即可。
Code
#include<cstdio>#include<cstring>using namespace std;const int N=2e6+1;int f[41],dis[N],que[N];bool bz[N];inline int read(){ int X=0,w=1; char ch=0; while(ch<'0' || ch>'9') {if(ch=='-') w=-1;ch=getchar();} while(ch>='0' && ch<='9') X=(X<<3)+(X<<1)+ch-'0',ch=getchar(); return X*w;}int main(){ int n=read(),q=read(); for(int i=1;i<=n;i++) f[i]=read(); for(int i=0;i<20;i++) f[++n]=1<<i; int l=que[1]=dis[0]=0,r=bz[0]=1; while(l<r) { int x=que[++l]; for(int i=1;i<=n;i++) { int y=x^f[i]; if(!bz[y]) { dis[y]=dis[x]+1; bz[que[++r]=y]=true; } } } while(q--) printf("%d\n",dis[read()^read()]); return 0;}
- JZOJ 100047. 【NOIP2017提高A组模拟7.14】基因变异
- [jzoj100047]【NOIP2017提高A组模拟7.14】基因变异
- JZOJ100047. 【NOIP2017提高A组模拟7.14】基因变异
- JZOJ 100046. 【NOIP2017提高A组模拟7.14】收集卡片
- 【JZOJ 4931】【NOIP2017提高组模拟12.24】A
- 【JZOJ 4931】【NOIP2017提高组模拟12.24】A
- JZOJ 5195. 【NOIP2017提高组模拟7.3】A
- JZOJ 100026. 【NOIP2017提高A组模拟7.7】图
- JZOJ 100030. 【NOIP2017提高A组模拟7.8】为了爱情
- jzoj. 100031. 【NOIP2017提高A组模拟7.9】外星密码
- JZOJ 100035【NOIP2017提高A组模拟7.10】区间
- JZOJ 100036 【NOIP2017提高A组模拟7.10】随机
- JZOJ 100037【NOIP2017提高A组模拟7.11】后缀数组
- JZOJ 100035. 【NOIP2017提高A组模拟7.10】区间
- JZOJ 100041. 【NOIP2017提高A组模拟7.12】列车调度
- JZOJ 100045. 【NOIP2017提高A组模拟7.13】好数
- 【JZOJ 5249】【NOIP2017提高A组模拟8.10】文本编辑器
- JZOJ 5305. 【NOIP2017提高A组模拟8.18】C
- 增量式PID控制算法
- 整数划分
- JZOJ__Day 9:【普及模拟】算法学习(sfxx)
- 嵌入式每日学习心得2017.07.14
- React-Native 命令备忘
- JZOJ 100047. 【NOIP2017提高A组模拟7.14】基因变异
- Java多线程____Executors线程池的使用和架构原理
- Pinhole camera model相机模型
- 【GDOI2018模拟7.14】小奇的糖果 树状数组+扫描线
- 关于请求能抓包到数据但是request取不到数据的问题
- Dagger2在Android开发中的应用
- win32汇编-使用子程序以及堆栈平衡原理
- 使用plsq实现文件压缩zip
- html+css实现子div在父div中居中