蓝桥杯-生物芯片
来源:互联网 发布:全球云计算开源大会 编辑:程序博客网 时间:2024/06/05 11:06
题目
标题:生物芯片
X博士正在研究一种生物芯片,其逻辑密集度、容量都远远高于普通的半导体芯片。
博士在芯片中设计了 n 个微型光源,每个光源操作一次就会改变其状态,即:点亮转为关闭,或关闭转为点亮。
这些光源的编号从 1 到 n,开始的时候所有光源都是关闭的。
博士计划在芯片上执行如下动作:
所有编号为2的倍数的光源操作一次,也就是把 2 4 6 8 … 等序号光源打开
所有编号为3的倍数的光源操作一次, 也就是对 3 6 9 … 等序号光源操作,注意此时6号光源又关闭了。
所有编号为4的倍数的光源操作一次。
…..
直到编号为 n 的倍数的光源操作一次。
X博士想知道:经过这些操作后,某个区间中的哪些光源是点亮的。
【输入格式】
3个用空格分开的整数:N L R ( L < R < N < 10^15 )
N表示光源数,L表示区间的左边界,R表示区间的右边界。【输出格式】
输出1个整数,表示经过所有操作后,[L,R] 区间中有多少个光源是点亮的。例如:
输入:
5 2 3
程序应该输出:
2再例如:
输入:
10 3 6
程序应该输出:
3
下面直接上代码
- 代码
import java.util.Scanner;public class Biochip { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String[] s = sc.nextLine().trim().split("\\s+"); int N = Integer.parseInt(s[0]); int L = Integer.parseInt(s[1]); int R = Integer.parseInt(s[2]); boolean[] lighted = new boolean[R-L+1]; int cnt = 0; for(int i=L;i<=R;i++) { for(int j=2;j<=i;j++) { if(i%j==0) lighted[i-L] = !lighted[i-L]; } if(lighted[i-L]) cnt++; } System.out.println(cnt); }}
- 结果
100 50 8433
0 0
- 蓝桥杯+生物芯片
- 蓝桥杯-生物芯片
- 蓝桥杯——生物芯片
- 蓝桥杯 生物芯片(java题解)
- 生物芯片
- 生物芯片
- 2014蓝桥杯决赛 本科B组 生物芯片
- 【发现的一道有意思的题】生物芯片(蓝桥杯2014国赛)
- Affymetrix生物芯片解决方案概述
- 生物芯片 完全平方数
- 第五届蓝桥杯决赛 生物芯片(完全平方数)
- 生物芯片(关灯问题 质因数分解定理)
- 2014年第五届蓝桥杯C/C++程序设计本科B组决赛 生物芯片(编程大题)
- 2014年第五届蓝桥杯C/C++程序设计本科B组决赛 生物芯片(编程大题)
- 【2014年第五届蓝桥杯C/C++程序设计本科B组决赛 生物芯片(编程大题) 】
- 蓝桥杯
- 蓝桥杯
- 蓝桥杯
- 初识Lucene全文索引
- 棋盘分割
- Delphi COM编程技术二(COM接口和COM组件)
- Linux平台设备和驱动
- 二叉树中找到俩个节点的最低公共祖先
- 蓝桥杯-生物芯片
- 欢迎使用CSDN-markdown编辑器
- Android进程保活招式大全
- C++库资源汇总
- MySQL簇的基本概念
- OSI七层协议
- Vue.js的组件(二)父组件与子组件的数据联系 之 父传子
- 命令行快捷键
- Logistic回归原理详解2