强训之【求最大连续的bit数和最近公共祖先】

news2024/9/29 17:37:20

目录

  • 1.求最大连续的bit数
    • 1.1题目
    • 1.2思路
      • 1.2.1暴力求解
      • 1.2.2 字符串分割求解
      • 1.2.3 位运算“与”求解
    • 1.3代码
      • 1.3.1暴力求解代码
      • 1.3.2字符串分割求解代码
      • 1.3.3位运算“与”求解
  • 2.最近公共祖先
    • 2.1题目
    • 2.2思路
    • 2.3代码
  • 3.选择题

1.求最大连续的bit数

1.1题目

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

数据范围:数据组数:1\le t\le 5\1≤t≤5 ,1\le n\le 500000\1≤n≤500000
进阶:时间复杂度:O(logn)\O(logn) ,空间复杂度:O(1)\O(1)
输入描述:
输入一个int类型数字

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

示例1
输入:
200

输出:
2

说明:
200的二进制表示是11001000,最多有2个连续的1。

1.2思路

1.2.1暴力求解

暴力求解是最容易理解的方法。

 将整数求余后,利用字符串拼接,因为此时的二进制数是反的,所以要反转一下。
注意要将StringBuilder的sb字符串变为String类型的。

 然后判断每一位是否等于1,等于1就count++,遇到0的时候判断count和ret的大小,将大值给ret,并且将count置为0,再循环。

为了防止最后几位都是1,所以最后判断一下,count和ret的大小,将大的一方,赋值给ret。

1.2.2 字符串分割求解

利用Integer.toBinaryString()直接将整数变为二进制数的字符串形式。
然后利用库函数spilt,用“0”作为分割线,字符数组的每一个都是字符1,最后判断字符数组中的最长字符串的长度。

1.2.3 位运算“与”求解

大家都知道**任何一个数&1,如果这个数的二进制末尾是1,那么结果就是1,如果末尾是0,那么结果就是0.**
根据这个判断,结果等于1,count++,遇到0的时候判断count和ret的大小,将大值给ret,并且将count置为0,再循环。

为了防止最后几位都是1,所以最后判断一下,count和ret的大小,将大的一方,赋值给ret。

1.3代码

1.3.1暴力求解代码

import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n=in.nextInt();
        StringBuilder sb=new StringBuilder();
        while(n>0)
        {
            int a=n%2;
            sb.append(a+"");
            n=n/2;
        }
        sb.reverse();
        String str=sb.toString();
        char[] ch=str.toCharArray();

        int count=0;
        int ret=0;

        for(int i=0;i<ch.length;i++)//1110101
        {
            if(ch[i]=='1')
            {
                count++;//2//1
            }
            if(ch[i]=='0')
            {
                if(count>ret)
                {
                    ret=count;//2

                }
                count=0;
            }
        }
        if(count>=ret)
        {
            ret=count;
        }
        System.out.println(ret);
    }
}

1.3.2字符串分割求解代码

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n=in.nextInt();
        String str1=Integer.toBinaryString(n);
        String[] str=str1.split("0");
        int count=0;
        for(int i=0;i<str.length;i++)
        {
            if(str[i].length()>count)
            {
                count=str[i].length();
            }

        }
        System.out.println(count);
    }
}

1.3.3位运算“与”求解

import java.util.Scanner;

// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
       int n=in.nextInt();
       int count=0;
       int ret=0;
       while(n!=0)
       {
        if((n&1)==1)
        {
            count++;
        }
        if((n&1)==0)
        {
            if(count>ret)
            {
                ret=count;
            }
            count=0;
        }
        n=n>>1;

       }
       if(count>ret)
       {
        ret =count;
       }
       System.out.println(ret);
    }
}

2.最近公共祖先

2.1题目

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

测试样例:
2,3
返回:1

2.2思路

首先判断A是否等于B,如果等于的话,任何一个都是最近公共祖先。

当A!= B的时候,我们知道父节点=孩子节点/2,所以我们让,较大的数/2,再和另外一个判断,如果不相等就在取最大的数,然后除以2,知道A和B相等。这个时候,A的值,就是父亲节点。
在这里插入图片描述

2.3代码

import java.util.*;

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

3.选择题

  1. 下面哪个标识符是合法的?(D
    A 9HelloWorld
    B _Hello World
    C Hello*World
    D Hello$World

标识符开头不能是数字,中间也不能有空格,也不能有 * 等特殊的字符

2.以下java程序代码,执行后的结果是(C
java.util.HashMap map=new java.util.HashMap();
map.put(“name”,null);
map.put(“name”,“Jack”);
System.out.println(map.size());
A 0
B null
C 1
D 2

map是有键值对的,键(只有一个)和值(可以有多个)
当开始键为 name 值为null
后来键不变,值覆盖为jack
所以大小还是1个

  1. Java中的集合类包括ArrayList、LinkedList、HashMap等类,下列关于集合类描述错误的是(C

A ArrayList和LinkedList均实现了List接口
B ArrayList的访问速度比LinkedList快
C 添加和删除元素时,ArrayList的表现更佳
D HashMap实现Map接口,它允许任何类型的键和值对象,并允许将null用作键或值

ArrayList的访问速度比LinkedList快,因为ArrayList的底层是数组,LinkedList是链表
添加和删除元素时,ArrayList更慢,LinkedList更快,因为ArrayList的底层是数组,添加的时候需要一个一个访问,链表直接添加一个节点就可以

  1. 以下描述正确的是(B
    A CallableStatement是PreparedStatement的父接口
    B PreparedStatement是CallableStatement的父接口
    C CallableStatement是Statement的父接口
    D PreparedStatement是Statement的父接口

PreparedStatement是CallableStatement的父接口
Statement是CallableStatement的父接口

  1. 下面有关重载函数的说法中正确的是(C
    A 重载函数必须具有不同的返回值类型
    B 重载函数形参个数必须不同
    C 重载函数必须有不同的形参列表
    D 重载函数名可以不同

重载可以是,参数类型不同,个数不同,返回值可以不同,函数名必须相同

  1. 下列关于容器集合类的说法正确的是?(C
    A LinkedList继承自List
    B AbstractSet继承自Set
    C HashSet继承自AbstractSet
    D WeakMap继承自HashMap

LIst和Set是接口,只能实现不能继承

  1. ArrayList list = new ArrayList(20);中的list扩充几次(A
    A 0
    B 1
    C 2
    D 3

当我们new的时候给定大小20,此时不会扩容
但是当我们不给与大小的时候,默认为10,当我们添加到第11个时候,就会扩容1.5倍

在这里插入图片描述
8. 以下程序的输出结果是?(B
public class Example {
String str = new String(“good”);
char[] ch = { ‘a’, ‘b’, ‘c’ };
public static void main(String args[]) {
Example ex = new Example();
ex.change(ex.str, ex.ch);
System.out.print(ex.str + " and ");
System.out.print(ex.ch);
}
public static void change(String str, char ch[])
{
str = “test ok”;
ch[0] = ‘g’;
}
}
A good and abc
B good and gbc
C test ok and abc
D test ok and gbc

  1. 下面的方法,当输入为2的时候返回值是多少?(D
    public static int getValue(int i) {
    int result = 0;
    switch (i) {
    case 1:
    result = result + i;
    case 2:
    result = result + i * 2;
    case 3:
    result = result + i * 3;
    }
    return result;
    }
    A 0
    B 2
    C 4
    D 10

当i=2的时候,我们先执行case 2语句,此时result=4,不过因为没有break,所以还会往下执行case 3.此时结束result=4+2*3=10。
需要注意,此时** i 依然等于2**

  1. 提供Java存取数据库能力的包是(A
    A java.sql
    B java.awt
    C java.lang
    D java.swing

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/438292.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《花雕学AI》21:ChatGPT能否应对脑筋急转弯?逻辑推理和创造性思维的大考验!

当我们谈到脑筋急转弯时&#xff0c;很多人都会感到兴趣和好奇。脑筋急转弯是一种智力游戏&#xff0c;可以锻炼我们的思维能力以及解决问题的能力。然而&#xff0c;对于许多人来说&#xff0c;脑筋急转弯也是一项相当具有挑战性的任务。在这个过程中&#xff0c;我们需要运用…

RISE with SAP,亚马逊云科技开启全新的SAP现代化之路

在不确定性依然存在的当下&#xff0c;快速进行现代化转型与创新&#xff0c;是企业走向成功的必经之路。而现代化转型与创新对于众多企业而言&#xff0c;意味着对SAP进行现代化改造。实现这一改造&#xff0c;能为企业带来包括创新业务模型、快速响应客户不断变化的需求、增加…

推荐系统数据集之MovieLens

1.概述 MovieLens其实是一个推荐系统和虚拟社区网站&#xff0c;它由美国 Minnesota 大学计算机科学与工程学院的GroupLens项目组创办&#xff0c;是一个非商业性质的、以研究为目的的实验性站点。GroupLens研究组根据MovieLens网站提供的数据制作了MovieLens数据集合&#xff…

带有MCU算法的多功能语音交互芯片,OTA升级语音ic,WTV380-32N

几年来&#xff0c;随着智能家居、安防报警、医疗器械 等领域的快速发展&#xff0c;语音交互技术越来越受到人们的关注和青睐。作为智能硬件的重要组成部分&#xff0c;语音芯片的发展也变得越来越重要&#xff0c;针对这一市场需求&#xff0c;我们推出了一款多功能的语音芯片…

layout布局input框输入中文出现撑开/换行

layout布局input框输入中文出现撑开/换行 问题 element ui组件库中提供了layout布局&#xff0c;但是在使用中出现了一个奇奇怪怪的问题 我想要实现的布局是两个输入框排成一行&#xff0c;行与行之间样式布局不会互相影响 直接上代码&#xff1a; <el-row :gutter&quo…

海康相机通过MVS达不到标称最大帧率的解决办法

目录 1.相机参数设置1.1 取消相机帧率限制1.2 修改相机图像格式1.3 调整相机曝光时间1.4 检查相机数据包大小&#xff08;网口相机特有参数&#xff09;1.5 恢复相机默认参数1.6 相机 ADC 输出位深调整 2.系统环境设置2.1 网口相机设置2.2 USB 相机设置 1.相机参数设置 1.1 取…

pycharm flask断点调试失效

问题描述 在升级本地pycharm为最新版pycharm2023.1后&#xff0c;发现原有的flask项目下的断点怎么都无法进入调试。同时&#xff0c;如果是debug某个py文件是可以正常进入调试的&#xff0c;因此推断这与flask有关。 pycharm&#xff1a;PyCharm 2023.1 (Professional Editio…

STM32HAL库 OLED显示屏的使用

文章目录 前言一、CubeIDE配置OLED显示屏iic引脚二、OLED驱动库1.引入库2.main.c中使用 总结 前言 本文主要讲解hal库配置与0.96寸oled屏的使用。 一、CubeIDE配置OLED显示屏iic引脚 OLED显示屏需要用到iic通信&#xff0c;此处选择了选择pb8为SCL、pb9为SDA 二、OLED驱动…

vue2数据响应式原理(1) view-model概念,侵入式和非侵入式对比

都是练拳不练功 到头一场空 在更新技术视野的前提下 还是要去多学原理 掌握更深的技术范畴 我会先出文后续持续更新 讲解vue2响应式原理 至于vue3 后续有机会 也会弄 这些文章不会直降理论 到一定阶段 也会带大家手写代码去实现一下效果 首先是 view-model 大家在实际开发中应…

SpringBoot集成Mybatis-Plus实现多租户动态数据源

1. 概述 最近接手一个多租户系统&#xff0c;多租户主要的就是租户之间的数据是相互隔离的&#xff0c;每个租户拥有自己独立的数据&#xff0c;相互之间不干扰。目前实现多租户主要有三种方案&#xff1a; 独立数据库 每个租户拥有自己单独的数据库&#xff0c;从物理上隔离了…

Java语言数据类型与c语言数据类型的不同

目录 一、c语言数据类型 1.基本类型&#xff1a; 2.枚举类型&#xff1a; 3.空类型&#xff1a; 4.派生类型&#xff1a; 二、C语言编程需要注意的64位和32机器的区别 三、 不同之处 一、c语言数据类型 首先&#xff0c;先来整体介绍一下C语言的数据类型分类。 1.基…

空间金字塔池化(Spatial Pyramid Pooling)

1. 前言 当前的深度神经网络一般都需要固定的输入图像尺寸&#xff08;如224*224&#xff09;。这种需求很明显是人为的&#xff0c;潜在性的弊端会降低识别精度&#xff08;为了使图像尺寸相同&#xff0c;一定会涉及到图像的比例/非比例放缩&#xff0c;这就引入了尺度误差和…

机器学习中的三个重要环节:训练、验证、测试

本文重点 模型训练、验证和测试是机器学习中的三个重要环节。这三个环节之间存在着紧密的关系,它们相互作用,共同构建出一个完整的机器学习模型。在本文中,我们将详细介绍模型训练、验证和测试之间的关系。 模型训练、验证和测试之间的关系 模型训练是机器学习中最基本的…

原生Java使用Mybatis操作数据库接口注解形式,与SpringBoot类似且无需管理SqlSession连接的工具类

Hi I’m Shendi https://sdpro.top/blog/html/article/1044.html 需求描述 用 SpringBoot 整合 Mybatis 使用久了&#xff0c;再编写没有Spring但需要操作数据库的程序时就会想着使用接口注解的形式&#xff0c;这样效率比较高和简单 Spring 中只需要编写好接口映射&#xff…

字节跳动正式开源分布式训练调度框架 Primus

动手点关注 干货不迷路 项目地址&#xff1a;https://github.com/bytedance/primus 随着机器学习的发展&#xff0c;模型及训练模型所需的数据量越来越大&#xff0c;也都趋向于通过分布式训练实现。而算法工程师通常需要对这些分布式框架涉及到的底层文件存储和调度系统有较深…

剑指 Offer 52. 两个链表的第一个公共节点 / LeetCode 160. 相交链表(双指针 / 哈希集合)

题目&#xff1a; 链接&#xff1a;剑指 Offer 52. 两个链表的第一个公共节点&#xff1b;LeetCode 160. 相交链表 难度&#xff1a;简单 输入两个链表&#xff0c;找出它们的第一个公共节点。 如下面的两个链表&#xff1a; 在节点 c1 开始相交。 示例 1&#xff1a; 输入…

Spring MVC Bean加载控制

回顾一下我们一般写的项目包括那些包吧&#xff1a; config目录存入的是配置类,写过的配置类有: ServletContainersInitConfigSpringConfigSpringMvcConfigJdbcConfigMybatisConfig controller目录存放的是SpringMVC的controller类service目录存放的是service接口和实现类dao目…

Doo Prime 德璞资本:股指期货交易如何管理好个人情绪

在股指期货交易中&#xff0c;我们可以感觉到心态随着交易的成败而变化。有时心态对交易影响不大&#xff0c;但有时影响很大&#xff0c;一个好的心态&#xff0c;能够应对各种变化&#xff0c;各种损益和市场判断的正确和错误&#xff0c;不会对心态产生很大的影响&#xff0…

ArcGIS中的土地利用变化分析详解

本篇主要是针对矢量数据的分析。 一、不同时期的土地利用矢量数据&#xff0c;如何分析其图形及属性变化&#xff1f; 土地利用图&#xff08;左图为1993年&#xff0c;右图为2003年&#xff09; 思路如下&#xff1a; 可以先对2个图层进行Union操作&#xff0c;然后在结果中…

【三十天精通Vue 3】第十四天 Vue 3 的单元测试详解

✅创作者&#xff1a;陈书予 &#x1f389;个人主页&#xff1a;陈书予的个人主页 &#x1f341;陈书予的个人社区&#xff0c;欢迎你的加入: 陈书予的社区 &#x1f31f;专栏地址: 三十天精通 Vue 3 文章目录 引言一、为什么要进行单元测试1.1 单元测试的概念1.2 单元测试的优…