【java】笔试强训Day3【在字符串中找出连续最长的数字串与数组中出现次数超过一半的数字】

目录

⛳选择题

1.以下代码运行输出的是

2.以下程序的输出结果为

3.下面关于构造方法的说法不正确的是 (        )

4.在异常处理中,以下描述不正确的有(        )

5.下列描述中,错误的是(        )

6.下列哪种说法是正确的?

7.有以下代码片段: 请问输出的结果是(        )

8.程序读入用户输入的一个值,要求创建一个自定义的异常,如果输入值大于 10 ,使用 throw 语句显式地引发异常,异常输出信息为 ”something’swrong!” , 语句为(        )

9.以下关于集合类 ArrayList 、 LinkedList 、 HashMap 描述错误的是(        )

10.Java程序中的类名必须与存放该类的文件名相同

🔥编程题

1.在字符串中找出连续最长的数字串

2.数组中出现次数超过一半的数字


⛳选择题

1.以下代码运行输出的是


public class Person{
    private String name = "Person";
        int age=0;
    }
public class Child extends Person{
    public String grade;
    public static void main(String[] args){
        Person p = new Child();
        System.out.println(p.name);
    }

}

A 输出:Person                   B 没有输出                  C 编译出错                       D 运行出错

🙈大家觉得答案是什么呢


🙉答案是 C 啦~

🔎思路分析:

Person 中的 nameprivate 修饰符修饰的只能在类内进行访问

通过 p 调用 name

2.以下程序的输出结果为

class Base{
    public Base(String s){
        System.out.print("B");
    }
}
public class Derived extends Base{
    public Derived (String s) {
        System.out.print("D");
    }
    public static void main(String[] args){
        new Derived("C");
    }
}

A、BD                      B、 DB                    C、C                   D、编译错误

🙈大家觉得答案是什么呢


🙉答案是 D 啦~

🔎思路分析:本题考查的是 继承 

由题可得:父类带有一个参数的构造方法,就不会提供不带参数的构造方法

此时,子类要帮助父类构造方法,而父类是一个带有一个参数的构造方法,因此此时要用 关键字super 调用构造方法

这时候编译就出错了

3.下面关于构造方法的说法不正确的是 (        )

A 构造方法也属于类的方法,可以创建对象的时候给成员变量赋值

B 构造方法不可以重载

C 构造方法没有返回值

D 构造方法一定要和类名相同

🙈大家觉得答案是什么呢


🙉答案是 B 啦~

🔎思路分析:构造方法也属于类方法,有无参构造也有有参构造,并且在一个类中两种构造可以都存在,可以创建对象的时候给成员变量赋值 ,所以构造方法可以重载。构造方法一定要和类名相同,并给构造方法没有返回值。

4.在异常处理中,以下描述不正确的有(        )

A try块不可以省略

B 可以使用多重catch块

C finally块可以省略

D catch块和finally块可以同时省略

🙈大家觉得答案是什么呢


🙉答案是 啦~

🔎思路分析:在异常处理中 try 与 catch 块是不可以省略的,并给 catch 块可以写很多个;而 finally 块可以省略

5.下列描述中,错误的是(        )

A SQL语言又称为结构化查询语言

B java中”static”关键字表明一个成员变量或者是成员方法可以在没有所属的类的实例变量的情况下被访问

C 面向对象开发中,引用传递意味着传递的并不是实际的对象,而是对象的引用,因此,外部对引用对象所做的改变不会反映到所引用的对象上

D java是强类型语言,javascript是弱类型语言 E 面向对象的三大特性包括:封装,继承,多态

🙈大家觉得答案是什么呢


🙉答案是 啦~

6.下列哪种说法是正确的?

A 实例方法可直接调用超类的实例方法

B 实例方法可直接调用超类的类方法

C 实例方法可直接调用本类的类方法

D 实例方法可直接调用其他类的实例方法

🙈大家觉得答案是什么呢


🙉答案是 啦~

🔎思路分析

A 中如果要调用超类的构造方法应该使用:super 调用

B 中超类的类党法即静态方法:通过 类名 调用

D 中其他类的实例方法需要通过:其他类调用

7.有以下代码片段: 请问输出的结果是(        )

String str1="hello";
String str2="he"+ new String("llo");
System.out.println(str1==str2);

A true               B 都不对               C null                    D false

🙈大家觉得答案是什么呢


🙉答案是 啦~

🔎思路分析str1 存放的是常量池的地址str2 中拼接成新的对象,对象在堆上,因此 str2 存的是堆上的地址,则输出 false

8.程序读入用户输入的一个值,要求创建一个自定义的异常,如果输入值大于 10 ,使用 throw 语句显式地引发异常,异常输出信息为 ”something’swrong!” , 语句为(        )

A if(i>10)throw new Exception("something’swrong!");

B if(i>10)throw Exception e("something’swrong!");

C if(i>10) throw new Exception e("something’swrong!");

D if(i>10)throw Exception( "something’swrong!");

🙈大家觉得答案是什么呢


🙉答案是 啦~

🔎思路分析:这是在抛异常,而异常是一个类,则没有 new 是错误的,并且是类名小括号,不可以有其他的

thorw的使用格式是:throw new Exception("语句")

9.以下关于集合类 ArrayList 、 LinkedList 、 HashMap 描述错误的是(        )

A HashMap实现Map接口,它允许任何类型的键和值对象,并允许将null用作键或值

B ArrayList和LinkedList均实现了List接口

C 添加和删除元素时,ArrayList的表现更佳

D ArrayList的访问速度比LinkedList快 

🙈大家觉得答案是什么呢


🙉答案是 啦~

🔎思路分析:HashMap实现了Map接口,它允许任何类型的键和值对象,并允许将null用作键或值。ArrayList和LinkedList均实现了List接口。ArrayList的访问速度比LinkedList快,LinkedList需要遍历访问。

添加和删除元素时,ArrayList的表现最差,因为1️⃣添加元素的时候,需要把这个元素插入到数组中,那么之后的元素都需要向后移动2️⃣删除这个元素的时候,需要把之后的元素都向前移动; 因此 ArrayList 不适合用来添加和删除元素,而是用来查找,并且是通过下表进行查找

10.Java程序中的类名必须与存放该类的文件名相同

A 对                B 错

🙈大家觉得答案是什么呢


🙉答案是 啦~

🔥编程题

1.在字符串中找出连续最长的数字串

牛客网链接: 字符串中找出连续最长的数字串

描述:读入一个字符串str,输出字符串str中的连续最长的数字串

输入描述:个测试输入包含1个测试用例,一个字符串str,长度不超过255。

输出描述:在一行内输出str中里连续最长的数字串。

示例1

输入:abcd12345ed125ss123456789

输出:123456789

🔎思路分析首先我们需要定义一个 String cur 和 String ret , cur 里存放的是数字串 , ret 里存放的是最终的数字串

1️⃣定义一个 i , 用来遍历字符串 , 首先我们需要把字符串中的字符拿到 , 用来判断是不是数字 

2️⃣如果是 数字 , 则放入到 cur 中 

3️⃣如果下一个不是字符串 , 则让 cur 中的数组串长度与 ret 中的数字串长度进行比较 , 如果是 cur 中的数组串长度大 , 则使 ret = cur ; 如果 ret 中的数字串长度大 , 则令 cur = "";意味着把 cur 中的数字串清空

 

 

4️⃣❗❗❗最重要的是 , 假设这个字符串最终是由 数字 结尾 , 那么就会出现问题 : 

因此这个时候就需要我们加一个条件 : 假如 i 达到了字符串的长度之后 , 判断 cur 中的数组串长度与 ret 中的数字串长度进行比较 , 如果是 cur 中的数组串长度大 , 更新 ret 中的数字串

    import java.util.Scanner;
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String str = scanner.nextLine();
        String cur = "";//符合的数字串放入
        String ret = "";//用来存放最终的数字串结果
        int i = 0;
        for (i = 0; i < str.length(); i++) {
            char ch = str.charAt(i);//查找字符串中每个字符
            if (ch >= '0' && ch <= '9') {
                cur = cur + ch + "";//字符串与字符拼接+““
            } else {
                if (cur.length() > ret.length()) {
                    ret = cur;
                } else {
                    cur = "";
                }
            }
        }
        if (i == str.length() && cur.length() > ret.length()) {
            ret = cur;
        }
        System.out.println(ret);
    }

2.数组中出现次数超过一半的数字

牛客网链接 : 数组中出现次数超过一半的数字

描述 : 给一个长度为 n 的数组,数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组[1,2,3,2,2,2,5,4,2]。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。

数据范围:n≤50000,数组中元素的值 0≤val≤10000             要求:空间复杂度:O(1),时间复杂度 O(n)

输入描述:保证数组输入非空,且保证有解

示例1

输入:[1,2,3,2,2,2,5,4,2]

返回值:2

示例2

输入:[3,3,3,3,2,2,2]

返回值:3

🔎思路分析 : 这里给两种方法

第一种 : 排序

1️⃣找到中间数字

2️⃣再次遍历数组,看一下这个数出现多少次

这个时候需要引出两个数,众数和非众数

如果两个数不相等,就消去这两个数,最坏的情况下,每次消去一个众数和非众数,那么如果存在众数,最后留下的数肯定是众数

    import java.util.Arrays;
    public static int MoreThanHalfNum_Solution(int[] array) {
        if (array.length < 1 && array == null) {
            return  0;
        }
        Arrays.sort(array);//排序
        int len = array.length;
        int midNum = array[len/2];//中间数

        int count = 0;
        //找出这个中间数出现的次数
        for (int i = 0; i < len; i++) {
            if (array[i] == midNum) {
                count++;
            }
        }
        //判断这个次数是否超过一半,如果超过返回这个众数
        if (count > len/2) {
            return midNum;
        }
        return 0;
    }

第二种:

假设输入1 3 2 2 2

1️⃣我们需要有一个 int result 和 int times , result 用来存放最终的结果 , times 用来存放出现的次数

2️⃣定义 result  和 times 为第一个数且出现的次数为 1 即 result = 1;times = 1;

3️⃣开始循环 i,从第二个数开始循环,与前一次比较,如果第二个数与第一个数不相等,则 times--;如果第二个数与第一个数相等,则 times++;再次循环,如果某个时候的 times = 0;就从这个数开始,重新定义 result 为这个数,即 result = arr[i],且 times = 1;

4️⃣❗❗❗非常重要的是,需要判断这个数是不是出现的次数大于数组的一半

遍历这个数组,判断 result 出现的次数是不是超过一半 

    public static int MoreThanHalfNum_Solution1(int[] array) {
        if (array == null && array.length < 1) {
            return 0;
        }

        int result = array[0];//存放第一个数
        int times = 1;//第一第一个数的次数为1

        for (int i = 1; i < array.length; i++) {//从第二个数开始i = 1

            if (times != 0) {
                if (array[i] != result) {
                    --times;
                } else {
                    ++times;
                }
            } else {
                result = array[i];//如果这个次数为0,就让result = 这个数
                times = 1;//次数设定为1
            }
        }

        //再次遍历数组,判断这个result 是不是 众数
        times = 0;
        for (int i = 0; i < array.length; i++) {
            if (array[i] == result) {
                times++;
            }
        }

        //次数大于一半,返回result
        if (times > array.length/2) {
            return result;
        }
        return 0;
    }

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux下的coredump和kdump

目录前言coredump是什么&#xff1f;运行异常代码查看本地文件多出的core文件gdb调试带上core文件kdump机制前言 在我们之前介绍进程等待的时候&#xff0c;曾经介绍过父进程会等待子进程并且回收子进程的运行结束状态&#xff08;status输出型参数&#xff09;:参考博客 当进…

【Node.js】身份认证,Cookie和Session的认证机制,express中使用session认证和JWT认证

Node.jsWeb开发模式如何选择Web开发模式身份认证什么是身份认证为什么要身份认证不同开发模式的身份认证Session认证机制提高身份认证的安全性Session的工作原理Express中使用Session认证Session认证机制的局限性JWT认证机制JWT的工作原理JWT的组成部分Express中使用JWT在登录成…

Java - 配置中心初体验

目录 前言 配置中心介绍 什么是配置中心 Nacos配置中心 数据结构 命名空间 分组 服务 配置中心添加配置 读取配置 本地添加依赖 本地添加配置 测试 结语 前言 前文讲了ELK&#xff0c;ELK说简单也简单&#xff0c;说复杂也复杂&#xff0c;但说实话&#xff0c;微…

数据库知识总结

数据库知识点总结个人向。 目录第一章 绪论第二章 关系数据库第三章 关系数据库标准语言SQL第四章 数据库安全性第五章 数据库完整性第六章 关系数据理论第七章 数据库设计第十章 数据库恢复技术第十一章 并发控制第一章 绪论 数据(data): 描述事物的符号记录。 数据库(DataB…

基于注解的Spring-AOP应用实例

1、应用场景 需求是&#xff1a;在a系统每次字典数据变更时&#xff0c;都需要给b系统同步一次数据&#xff0c;以保持两个系统字典数据相同。 字典的增、删、改、合并接口&#xff0c;都需要执行数据推送操作&#xff0c;如果不用AOP、这些接口都需要增加推送操作的代码&…

Docker常规安装简介

总体步骤 搜索镜像拉取镜像查看镜像启动镜像,服务端口映射停止容器移除容器 案例 安装tomcat docker hub上面查找tomcat镜像&#xff0c;docker search tomcat从docker hub上拉取tomcat镜像到本地 docker pull tomcatdocker images查看是否有拉取到的tomcat 使用tomcat镜像创…

【带有平移和倾斜头的DIY相机滑块–基于Arduino的项目】

【带有平移和倾斜头的DIY相机滑块–基于Arduino的项目】 1. 前言2. 总体构思3. 构建相机滑块4. 电路图5. 印刷电路板设计6. 组装电子设备7. DIY 相机滑块 Arduino 代码1. 前言 在本教程中,我们将学习如何制作带有平移和倾斜头的电动相机滑块。这个基于 Arduino 的项目是 100%…

【Linux】进程概念二

文章目录进程概念二1. 进程状态2. 进程状态查看3. 僵尸进程3.1 僵尸进程的危害4. 孤儿进程5. 环境变量5.1 常见环境变量5.2 查看环境变量的方法5.3 测试PATH5.4 环境变量相关的命令5.5 环境变量的组织方式5.6 通过代码获取环境变量6. 程序地址空间7. 进程地址空间8. 扩展8.1 为…

如何安装nvm(nvm 安装教程)

如何安装nvm(nvm 安装教程) 一、nvm是什么? nvm是一个node的版本管理工具,可以简单操作node版本的切换、安装、查看等等,与npm不同的是,npm是依赖包的管理工具。 二、安装nvm 1.nvm下载地址 https://github.com/coreybutler/nvm-windows/releases提示:1.nvm-setup.z…

功能测试转型测试开发年薪27W,又一名功能测试摆脱点点点,进了大厂

咱们直接开门见山&#xff0c;没错我的粉丝向我投来了喜报&#xff0c;从功能测试转型测试开发&#xff0c;进入大厂&#xff0c;摆脱最初级的点点点功能测试&#xff0c;拿到高薪&#xff0c;遗憾的是&#xff0c;这名粉丝因为个人原因没有经过指导就去面试了&#xff0c;否则…

CCM调试的理论依据

前言 很久之前在网上看到一些CCM的调试总结&#xff0c;但是没有理论依据&#xff0c;经过我本人的推理&#xff0c;以及和结果比对&#xff0c;这里总结一个我称之为色相环补色原理的调试理论。 CCM理论&#xff1a; CMOS sensor 使用颜色滤波阵列&#xff08;Color Filter…

YOLOV8改进:如何增加注意力模块?(以CBAM模块为例)

YOLOV8改进&#xff1a;如何增加注意力模块&#xff1f;&#xff08;以CBAM模块为例&#xff09;前言YOLOV8nn文件夹modules.pytask.pymodels文件夹总结前言 因为毕设用到了YOLO&#xff0c;鉴于最近V8刚出&#xff0c;因此考虑将注意力机制加入到v8中。 YOLOV8 代码地址&am…

蓝桥杯每日一真题——[蓝桥杯 2021 省 B] 杨辉三角形(二分+规律)

文章目录[蓝桥杯 2021 省 B] 杨辉三角形题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1提示思路&#xff1a;全部代码&#xff1a;[蓝桥杯 2021 省 B] 杨辉三角形 题目描述 下面的图形是著名的杨辉三角形: 如果我们按从上到下、从左到右的顺序把所有数排成一列&…

配置Maven环境变量

我们现在进行项目开发时&#xff0c;项目中一般都会有依赖包的存在&#xff0c;而这些依赖包一般都是利用Maven进行下载管理的。 一. 下载&安装 下载地址 maven下载地址如下&#xff0c;各位请选择对应系统的maven版本进行下载。 https://maven.apache.org/download.cgi…

做一个前端网页送给女朋友~轮播图+纪念日

文章目录1. 轮播图框架2. 轮播图大盒子实现1. 盒子及图片的可视化2. 将图片重叠起来并放入轮播图盒子中...相对定位与绝对定位3. 添加左右按钮4. 点击按钮跳转图片5. 鼠标离开图片轮播图按钮隐藏6. 添加小圆点按钮7. 点击小圆点跳转图片并且该小圆点变色8. 自动轮播9. 最后一步…

SoC设计流程

此为一个学习记录文&#xff0c;内容可能从书上《SoC设计方法与实现&#xff0c;郭炜等电子工业出版社》来&#xff0c;也可能从网络来。 目录 软、硬件协同设计&#xff1a; 基于标准单元的SoC设计流程&#xff1a; 软、硬件协同设计&#xff1a; SoC 通常被称作系统级芯片…

EasyExcel导入Excel文件,并对文件内容作

首页是pom文件导入EasyExcel的依赖 <dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>2.2.6</version> </dependency> mysql中添加三个字段做测试 自定义异常类 package com.exampl…

ABC278 F - Shiritori

不懂博弈和状压DP&#xff0c;今晚加训状压DP&#xff01;博弈太难了&#xff0c;东西太多了&#xff0c;等蓝桥杯打完再说QwQF - Shiritori (atcoder.jp)题意&#xff1a;思路&#xff1a;注意到数据范围是到16&#xff0c;因此可以考虑状压DP状态设计&#xff1a;&#xff08…

Java-Collections and Lambda

Java SE API know how 集合API 根据算法访选择合适集合 linkedlist不适合搜索 随机访问数据用hashmap 数据保持有序使用treemap 通过索引访问使用数组集合 同步和非同步 访问性能统计 与简单的非同步访问相比&#xff0c;使用任何数据保护技术都会有较小的损失 设置集合…

AI绘画关键词网站推荐 :轻松获取百万个提示词!完全免费

一、lexica.art 该网站拥有数百万Stable Diffusion案例的文字描述和图片&#xff0c;可以为大家提供足够的创作灵感。 使用上也很简单&#xff0c;只要在搜索框输入简单的关键词或上传图片&#xff0c;就能为你提供大量风格不同的照片。点击照片就能看到完整的AI关键词&#…