【Java笔试强训】Day11(CM24 最近公共祖先、HJ86 求最大连续bit数)

CM24 最近公共祖先

链接:最近公共祖先

题目:

将一棵无穷大满二叉树的结点按根结点一层一层地从左往右编号,根结点编号为1。现给定a,b为两个结点。设计一个算法,返回a、b最近的公共祖先的编号。注意其祖先也可能是结点本身。

题目解析:


代码实现:

java 复制代码
package Day11;

public class Day11_1 {
    public int getLCA(int a, int b) {
        // write code here
        while (a != b) {
            if (a > b) {
                a /= 2;
            }else {
                b /= 2;
            }
        }
        return a;
    }
}

HJ86 求最大连续bit数

链接:求最大连续bit数

题目:

求一个int类型数字对应的二进制数字中1的最大连续数,例如3的二进制为00000011,最大连续2个1

题目解析:

代码实现:

java 复制代码
package Day11;

import java.util.Scanner;

public class Day11_2 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        while (sc.hasNext()) {
            int n = sc.nextInt();
            int count = 0;
            int nowCount = 0;
            while (n != 0) {
                if ((n & 1) == 1) {
                    nowCount++;
                    count = Math.max(count, nowCount);
                } else {
                    nowCount = 0;
                }
                n >>= 1;
            }
            System.out.println(count);
        }
    }
}
相关推荐
小光学长5 分钟前
ssm手工艺品交易平台4xccvou1(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·spring
AAA.建材批发刘哥7 分钟前
03--C++ 类和对象中篇
linux·c语言·开发语言·c++·经验分享
jghhh0111 分钟前
MATLAB实现弹道仿真源代码
开发语言·matlab
拾荒的小海螺35 分钟前
C#:PdfiumViewer 高效解析和操作 PDF 的技术指南
开发语言·pdf·c#
人道领域37 分钟前
【零基础学java】(方法引用)
java·开发语言
Macbethad38 分钟前
TwinCAT半导体设备IO Simulator技术方案
开发语言
路漫聊架构1 小时前
Redis扫描大key利器Scan命令探秘
java·数据库·redis
qq_336313931 小时前
java基础-IO流(打印流)
java·开发语言
缺点内向1 小时前
C#: 精准掌控Excel工作流——激活工作表与选择单元格实战
开发语言·c#·excel
我命由我123451 小时前
Android Jetpack Compose - enableEdgeToEdge 函数、MaterialTheme 函数、remember 函数
android·java·java-ee·kotlin·android studio·android jetpack·android-studio