【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);
        }
    }
}
相关推荐
CodeByV5 分钟前
【C++】C++11:右值引用和移动语义
开发语言·c++
会编程的吕洞宾8 分钟前
Java Set集合:你的数据去重神器
java·后端·程序员
一水鉴天10 分钟前
整体设计 全面梳理复盘 之37 元级自动化引擎三体项目(Designer/Master/Transformer)划分确定 + 自用规划工具(增强版)
开发语言·算法·transformer·公共逻辑
q***656914 分钟前
Spring Data 什么是Spring Data 理解
java·后端·spring
WYS@不忘初心17 分钟前
在Eclipse IDE for Embedded C/C++ Developers软件中定义的宏,编译C源文件时编译器无法找到宏定义!
java·ide·eclipse
q***318921 分钟前
Spring Framework 中文官方文档
java·后端·spring
自学互联网24 分钟前
python爬虫入门案例day05:Pexels
开发语言·爬虫·python
头发还没掉光光28 分钟前
C/C++类型转换
c语言·开发语言·c++
馨谙36 分钟前
RHEL 存储堆栈完全解析:从硬件到应用的存储管理指南
服务器·开发语言·php
q***465242 分钟前
Spring Boot(七):Swagger 接口文档
java·spring boot·后端