【Java版oj】day11最近公共祖先、求最大连续bit数
创始人
2025-05-29 15:43:19
0

目录

 一、最近公共祖先

(1)原题再现

(2)问题分析

(3)完整代码

 二、求最大连续bit数

(1)原题再现

(2)问题分析

(3)完整代码


 一、最近公共祖先

(1)原题再现

最近公共祖先_牛客题霸_牛客网

描述

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

测试样例:

2,3

返回:1

(2)问题分析

        本题只是一道入门题,看似与树有关,其实只是简单的数学运算。对于二叉树父节点和子节点有一个关系:

若i>0,双亲序号:gif.latex?%5Cfrac%7Bi-1%7D%7B2%7D;i=0,i为根结点编号,无双亲结点
gif.latex?2i+1,否则无左孩子
gif.latex?2i+2,否则无右孩子

        根据这样的关系,只需要将两个孩子结点不断除以2,直到两数相等时,就是两个数的最近公共祖先。

2235faa69b064b77b33094d1b7631bcc.png

(3)完整代码

import java.util.*;public class LCA {public int getLCA(int a, int b) {// write code herewhile (a != b) {if (a < b) {b = b / 2;} else {a = a / 2;}}return a;}
}

2bb3fbbea94749e0b12309cf5d515ac2.png

 二、求最大连续bit数

(1)原题再现

求最大连续bit数_牛客题霸_牛客网

描述

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

输入描述:

输入一个int类型数字

输出描述:

输出转成二进制之后连续1的个数

示例1

输入:

200

输出:

2

(2)问题分析

        这道题很明显是一道动态规划的题。跟求解最长子序列类似。

        首先需要将十进制转化成二进制,并将二进制结果保存下来,我这里使用的是栈存储,可以保证得到的二进制顺序与实际的一致,其实也可以用StringBuffer类存储,无所谓顺序。得到二进制数的方法是,将该数不断除以2,得到余数,知道除数为0。

a1b4ca54e8c54e41a8b1fda975e14c22.png

        其次求求解连续1的最长序列 ,使用动态规划的思想。

状态:
子状态:F(i): 从0到i的连续一的个数
状态递推:

        如果当前下标位置为i的值为1时,连续1的个数就加一
              F(i) = F(i-1)+1

        如果当前下标位置为i的值为0时,连续1的个数就变为0

              F(i) = 0
初始化: 
              F(0) = 0(最开始是连续1的个数为0)
返回结果:右下角
              F(length)(数组长度)

每进行一次状态递推,就判断一次最大值和当前状态连续1的个数谁更大。

(3)完整代码

import java.util.*;
public class Main {public static void main(String[] args) {Deque stack = new LinkedList<>();//定义的栈存储二进制数Scanner sc = new Scanner(System.in);int num = sc.nextInt();stack = translate(stack, num);System.out.println(continueMax(stack));}public static Deque translate(Deque stack, int num) {//十进制转二进制int ans = 0;while (num != 0) {int tmp = num % 2;stack.push(tmp);//将余数压入栈中num /= 2;}return stack;}public static int continueMax(Deque stack) {int length = stack.size();int []oneSize = new int[length + 1];//长度是二进制数的个数+1,第0号位置用来初始化oneSize[0] = 0;int ans = oneSize[0];//定义初始连续1的最大数为0for (int i = 1; i <= length; i++) {//从第1号位置开始将二进制比特数出栈int tmp = stack.pop();//出栈,删除栈顶元素,并将栈顶元素的值赋给tmpif (tmp == 1) {//判断连续1的个数oneSize[i] = oneSize[i - 1] + 1;} else {oneSize[i] = 0;}ans = Math.max(ans, oneSize[i]);//每进行一次二进制数的出栈,就将现阶段连续1的个数与最大值比较}return ans;}
}

96d70111310a44ae8902d013409c2760.png

3ea9e174341b4b8daa7de7031662a6f8.png


相关内容

热门资讯

当对手都在做下沉 蜜雪冰城旗下... [ 今年5月,蜜雪集团跟巴西签署40亿元人民币的采购意向大单,其中大多数是咖啡豆。 ] 当星巴克、瑞...
新手必看!股指期货交易规则基础... 股指期货交易规则,看似复杂抽象,实则与我们的日常生活有着奇妙的共通之处。它就像一场精心编排的生活交响...
王登发履新茅台技开公司“一把手... 一则微信公众号发布的信息,披露了茅台集团旗下的技术开发公司“一把手”已换人。 近日,南都湾财社-酒水...
特斯拉机器人V3量产版亮相!马... 快科技7月27日消息,特斯拉的Optimus人形机器人V3量产版终于要来了!马斯克在最近的财报电话会...
原创 中... 在金融全球化的浪潮中,中国资本市场始终勇立潮头,不断探索前行。7月26日,中国资本市场学会成立大会暨...
报告:我国经济增长保持韧性 下... 央广网北京7月27日消息(记者 樊瑞)近日,中国金融四十人论坛(CF40论坛)发布《2025年第二季...
超6300亿元!A股银行“分红... 7月25日,成都银行完成权益分派股权登记,将于7月28日发放现金红利,这标志着A股上市银行2024年...
老铺黄金:2025年上半年单个... 7月27日晚,老铺黄金(HK06181)披露2025年中期业绩预告。预计2025年上半年实现销售业绩...
保险行业2025年上半年回顾与... 今天分享的是:保险行业2025年上半年回顾与未来展望 报告共计:59页 2025年上半年保险行业回顾...
数币App上新!消费者、商户两... 数字人民币试点持续推进,相关数字钱包手机应用程序功能也在优化中。7月21日,北京商报记者注意到,日前...
A股热点迭出,个股连续涨停!资... 近段时间以来A股市场整体走势较为强劲,上周以来在雅江概念集体上行的推动下涨势更为明显,主要指数不同程...
原创 印... 令人惊讶的是,印度人开始反思自身制造业的发展状况。印度经济学家帕纳加利亚指出,印度原本有机会在20年...
首创证券拟赴港上市,“A+H”... 首创证券在A股上市不足三年便启动赴港上市计划。近日,首创证券公告称,公司董事会已审议通过了公司拟发行...
肥东杨大爷要帮“儿子”还钱,银... “儿子”在外借了2万元还不上 “要债人”电话直接打了过来 还?还是不还? 7月6日 肥东县公安局梁园...
A股上周16家上市公司公布并购... 转自:扬子晚报 扬子晚报网7月27日讯(记者 范晓林 薄云峰)近段时间以来,A股市场并购重组活跃度持...
独家|某股份行改动零售业务关键... 在资产端信贷“投不动”(多家行零售信贷增速连续几个季度放缓、更有甚者个贷投放负增长)、负债端存款“定...
四川五日游报团指南及详细行程,... 四川,这片位于中国西南的神奇土地,以其独特的自然风光、丰富的文化遗产和诱人的美食而闻名遐迩。从成都的...
原创 中... 在2025年4月初,时任美国总统的特朗普正式启动了针对世界各国的关税战,旨在通过实施经济制裁来促进美...
牛市主升浪开启了?别急!珍惜布... 本周,A股市场上行,主要宽基指数都收获了或多或少的周涨幅,其中,科创50、微盘股涨幅居前。板块方面,...
公募二季报两大看点!港股配置逼... 本报(chinatimes.net.cn)记者栗鹏菲 叶青 北京报道 2025年公募基金二季报披露收...