- 最近公共祖先
- 思路
- 代码
- 求最大连续bit数
- 思路
- 代码
题目描述:将一棵无穷大满二叉树的结点按根结点一层一层地从左往右编号,根结点编号为1。现给定a,b为两个结点。设计一个算法,返回a、b最近的公共祖先的编号。注意其祖先也可能是结点本身。
示例:
输入:2,3
输出:1
链接:最近公共祖先
根据上面的二叉树父节点和子节点之间的关系root=child/2,如果a!=b,就让其中较大的除以2,如此循环知道ab,即是两个数的最近公共祖先,如a=2,b=3,b=3/2=1,2!=1,a=2/2=1,此时ab,所以最近的公共祖先是1.
import java.util.*; public class LCA { public int getLCA(int a, int b) { // write code here while(a!=b) { if(a>b) { a=a/2; } else { b=b/2; } } return a; } }d求最大连续bit数
题目描述:求一个int类型数字对应的二进制数字中1的最大连续数,例如3的二进制为00000011,最大连续2个1
本题含有多组样例输入。
输入描述:输入一个int类型数字。
输出描述:输出转成二进制之后连续的1的个数。
示例:
输入:
3
5
200
输出:
2
1
2
说明:3的二进制表示11,最多有2个连续的1.
5的二进制表示101,最多只有1个连续的1.
链接:求最大连续bit数
根据位运算,获取每一位的二进制值,获取第i位的值:(n>>i)&1.如果1连续,则计数累加,不联系,则从0开始。
代码import java.util.*; public class Main { public static void main(String[] args) { Scanner s=new Scanner(System.in); while(s.hasNext()) { int n=s.nextInt(); int max=0; int count=0; while(n!=0) { if((n&1)==1) { count++; max=Math.max(max,count); } else { count=0; } n>>=1; } System.out.println(max); } } }
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)