JAVA基础:数组 (习题笔记)

一,编码题

1,数组查找操作:定义一个长度为10 的一维字符串数组,在每一个元素存放一个单词;然后运行时从命令行输入一个单词,程序判断数组是否包含有这个单词,包含这个单词就打印出“Yes”,不包含就打印出“No”。

import java.util.*;public class PanTi {public static void main(String[] args) {String[] strArr = new String[10];strArr[0] = "java";strArr[1] = "html";strArr[2] = "sql";strArr[3] = "android";strArr[4] = "javascript";strArr[5] = "ruby";strArr[6] = "c";strArr[7] = "c++";strArr[8] = ".net";strArr[9] = "ios";Scanner scanner = new Scanner(System.in);System.out.print("请输入需要查找的计算机编程语言:");String inputStr = scanner.next();boolean flag = false;for (String string : strArr) {if (string.equals(inputStr)) {flag = true;}}if (flag) {System.out.println("YES");} else {System.out.println("NO");}}}

 

2,获取数组最大值和最小值操作:利用Java的Math类的random()方法,编写函数得到0到n之间的随机数,n是参数。并找出产生50个这样的随机数中最大的、最小的数,并统计其中>=60的有多少个。

提示:使用 int num=(int)(n*Math.random());获取随机数

import java.util.*;public class PanTi {public static void main(String[] args) {//创建一个长度为50的,每个元素在0-100之间的数组int[] arr = getArray(100);//遍历数组printArr(arr);//获取最大值和最小值int min = getMin(arr);int max = getMax(arr);System.out.println("数组中最大值:" + max + "\t数组中最小值:" + min);//统计其中大于等于60的元素个数int count = count(arr,60);System.out.println("数组中大于或等于60的数有:" + count + " 个");}//遍历数组private static void printArr(int[] arr) {System.out.println("输出数组元素");for(int i=0;i<arr.length;i++){if(i%10 ==0){System.out.println();}System.out.print(arr[i]+"\t");}}//获取数组最大值private static int getMax(int[] arr) {int max = arr[0];for(int i=1;i<arr.length;i++){if(max<arr[i]){max = arr[i];}}return max;}//获取数组最小值private static int getMin(int[] arr) {int min = arr[0];for(int i=0;i<arr.length;i++){if(min>arr[i]){min = arr[i];}}return min;}// 创建数组 并且初始化50个数据public static int[] getArray(int n) {int arr[] = new int[50];for (int i = 0; i < 50; i++) {arr[i] = (int) (n * Math.random());}return arr;}// 统计数组中大于等于60的数量的方法 思路:使用一个int值计数public static int count(int[] arr,int elem) {int count = 0;for (int i : arr) {if (i >= elem) {count++;}}return count;}
}

 

3,数组逆序操作:定义长度为10的数组,将数组元素对调,并输出对调前后的结果。

思路:把0索引和arr.length-1的元素交换,把1索引和arr.length-2的元素交换…..

只要交换到arr.length/2的时候即可。

import java.util.*;public class PanTi {public static void main(String[] args) {//定义一个数组,并进行静态初始化。int[] arr = {12, 98, 50, 34, 76, 87, 90, 34, 67, 80};//逆序前System.out.println("逆序前:");printArr(arr);//逆序后System.out.println("逆序后:");reverseArr(arr);printArr(arr);}public static void reverseArr(int[] arr) {for (int x = 0; x < arr.length / 2; x++) {int temp = arr[x];arr[x] = arr[arr.length - 1 - x];arr[arr.length - 1 - x] = temp;}}//遍历数组public static void printArr(int[] arr) {System.out.print("[");for (int x = 0; x < arr.length; x++) {if (x == arr.length - 1) { //这是最后一个元素System.out.println(arr[x] + "]");} else {System.out.print(arr[x] + ", ");}}}}

 

4,合并数组操作:现有如下一个数组:   int oldArr[]={1,3,4,5,0,0,6,6,0,5,4,7,6,7,0,5}   要求将以上数组中值为0的项去掉,将不为0的值存入一个新的数组,生成的新数组为: int newArr [] ={1,3,4,5,6,6,5,4,7,6,7,5}  

思路: 确定出不为0的个数,这样可以开辟新数组;从旧的数组之中,取出内容,并将其赋给新开辟的数组。

import java.util.*;public class PanTi {public static void main(String[] args) {int oldArr[] = {1, 3, 4, 5, 0, 0, 6, 6, 0, 5, 4, 7, 6, 7, 0, 5};int newArr[] = selectArr(oldArr);for (int i : newArr) {System.out.print(i + " ");}}// 去掉数组中值为0的元素的方法public static int[] selectArr(int[] arr) {// 1.计算数组中元素不为0的个数int count = 0;for (int i : arr) {if (i != 0) {count++;}}// 2.创建一个新数组,长度为countint newArr[] = new int[count];// 3.复制不为0的元素到新数组中int size = 0;for (int i : arr) {if (i != 0) {newArr[size++] = i;}}return newArr;}}

 

5,二分法查找操作:使用二分法查找有序数组中元素。找到返回索引,不存在输出-1。

分析:二分法查找的前提是数组有序。

假如有一组数为3,12,24,36,55,68,75,88要查给定的值24.可设三个变量front,mid,end分别指向数据的上界,中间和下界,mid=(front+end)/2.

  1. 开始令front=0(指向3),end=7(指向88),则mid=3(指向36)。因为mid>x,故应在前半段中查找。

  2. 令新的end=mid-1=2,而front=0不变,则新的mid=1。此时x>mid,故确定应在后半段中查找。

  3. 令新的front=mid+1=2,而end=2不变,则新mid=2,此时a[mid]=x,查找成功。

  4. 如要查找的数不是数列中的数,例如x=25,当第三次判断时,x>a[mid],按以上规律,令front=mid+1,即front=3,出现front>end的情况,表示查找不成功。

import java.util.*;public class PanTi {public static void main(String[] args) {int[] array = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};System.out.println(searchLoop(array, 9));}/*** 循环二分查找,返回第一次出现该值的位置** @param array     已排序的数组* @param findValue 需要找的值* @return 值在数组中的位置,从0开始。找不到返回-1*/public static int searchLoop(int[] array, int findValue) {// 如果数组为空,直接返回-1,即查找失败if (array == null) {return -1;}// 起始位置int start = 0;// 结束位置int end = array.length - 1;while (start <= end) {// 中间位置int middle = (start + end) / 2;// 中值int middleValue = array[middle];if (findValue == middleValue) {// 等于中值直接返回return middle;} else if (findValue < middleValue) {// 小于中值时在中值前面找end = middle - 1;} else {// 大于中值在中值后面找start = middle + 1;}}// 返回-1,即查找失败return -1;}}

6,二维数组遍历求和操作:用二重循环求出二维数组b所有元素的和:
 int[][] b={{11},{21,22},{31,32,33}}

import java.util.*;public class PanTi {public static void main(String[] args) {int sum = 0;int[][] b = {{11}, {21, 22}, {31, 32, 33}};for (int i = 0; i < b.length; i++) {for (int j = 0; j < b[i].length; j++) {sum += b[i][j];}}System.out.println(sum);}}

 

  • 可选题

1,生成一百个随机数,放入数组,然后排序输出。

import java.util.*;public class PanTi {public static void main(String[] args) {//1.生成100个随机数的数组int[] arr = createArr();//2.从小到大排序arr = sortArr(arr);//3.打印printArr(arr);}//生成100个随机数的方法public static int[] createArr() {int[] arr = new int[100];for (int i = 0; i < arr.length; i++) {arr[i] = (int) (100 * Math.random());}return arr;}//对数组进行排序的方法public static int[] sortArr(int arr[]) {int temp;for (int i = 0; i < arr.length; i++) {for (int j = 0; j <= i; j++) {if (arr[i] < arr[j]) {temp = arr[i];arr[i] = arr[j];arr[j] = temp;}}}return arr;}//数组遍历输出打印的方法public static void printArr(int[] arr) {for (int i : arr) {System.out.print(i + "\t");}}}

 

2,题目:输入某年某月某日,判断这一天是这一年的第几天?

分析:以3月5日为例,先把前两个月的加起来,然后再加上5天即本年第几天,特殊情况,闰年且输入月份大于3需考虑多加一天。可定义数组存储1-12月各月天数。

import java.util.*;public class PanTi {public static void main(String[] args) {Scanner scanner1 = new Scanner(System.in);System.out.print("输出今年是第几年");int year = scanner1.nextInt();System.out.print("输出本月是第几月");int month = scanner1.nextInt();System.out.print("输出今天是第几日");int day = scanner1.nextInt();int daynum = 0; // 天数//一年365天int[] month1 = new int[]{31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};//闰年366天if (year % 400 == 0 && year % 100 != 0 || year % 100 == 0) {month1 = new int[]{31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; // 闰年里的每个月的天数}//判断这一天是第几天for (int index = 1; index <= month; index++) {if (index == 1) {daynum = day;} else {daynum += month1[index - 2];}}System.out.println("这一天是这一年的第" + daynum + "天!");}}

 3, 数组A:1,7,9,11,13,15,17,19;数组b:2,4,6,8,10   ; 两个数组合并为数组c,按升序排列。 要求:使用Arrays类的方法快速实现。

import java.util.*;public class PanTi {public static void main(String[] args) {int data1[] = new int[]{1, 7, 9, 11, 13, 17, 19};int data2[] = new int[]{2, 4, 6, 8, 10};int newArr[] = concat(data1, data2);print(newArr);Arrays.sort(newArr);print(newArr);}public static int[] concat(int src1[], int src2[]) {int len = src1.length + src2.length; // 新数组的大小int arr[] = new int[len]; // 新数组
//		int count = 0;
//		for (int i : src1) {
//			arr[count++] = i;
//		}
//		for (int i : src2) {
//			arr[count++] = i;
//		}// 还可以通过系统的方法拷贝数组System.arraycopy(src1, 0, arr, 0, src1.length); // 拷贝第一个数组System.arraycopy(src2, 0, arr, src1.length, src2.length); //拷贝第二个数组return arr;}public static void print(int[] temp) {for (int x = 0; x < temp.length; x++) {System.out.print(temp[x] + "、");}System.out.println();}}

二,简答题

1,数组的特点。

  • 有序性‌:数组中的元素按照一定的顺序排列。
  • 类型一致性‌:数组中的所有元素必须是相同的数据类型。
  • 连续存储‌:数组中的元素在内存中连续存储,这使得访问数组元素时效率较高。
  • 索引访问‌:每个元素通过数组名和它在数组中的位置索引来访问,例如,array表示数组中的第一个元素。

2,数组的优缺点

  • 优点:

  1. 快速访问‌:‌数组按照索引查询元素的速度非常快,因为元素在内存中是连续存储的。
  2. 大量数据存储‌:数组适合存储大量数据,因为它可以快速访问和遍历。
  3. 随机访问‌:数组支持随机访问元素,只要知道元素的索引,就可以直接访问。
  4. 简单易用‌:数组的定义和使用非常简单,语法直观。
  5. 高效查找‌:利用二分查找等算法,数组可以高效地查找元素。
  • 缺点:

  1. 大小固定‌:数组的大小一旦确定,就不能改变,不适合动态存储。
  2. 类型单一‌:数组只能存储一种类型的数据。
  3. 插入和删除效率低‌:由于元素连续存储,插入和删除元素会导致大量元素移动,影响效率。
  4. 内存浪费‌:如果数组中存储的元素少于其声明的大小,会导致内存浪费。
  5. 容易溢出‌:如果访问超出数组边界的元素,可能会导致程序错误或异常。

3,冒泡排序的算法。

  • 定义:

                 冒泡排序是一种简单的排序算法,其基本思想是通过重复遍历待排序的数列,比较相邻元素的大小,如果它们的顺序错误则交换它们的位置。这个过程会重复进行,直到没有需要交换的元素为止。

  • 冒泡排序的基本步骤:

  1. 初始化‌:设定一个标志位(通常是布尔值),用于优化算法(可选)。

  2. 遍历数列‌:从数列的第一个元素开始,到倒数第二个元素结束。

  3. 比较和交换‌:比较相邻的两个元素,如果前一个元素比后一个元素大(对于升序排序),则交换它们的位置。

  4. 优化‌:如果在一次完整的遍历中没有发生任何交换,说明数列已经有序,可以提前结束排序。

  5. 重复‌:重复步骤2到步骤4,直到没有需要交换的元素为止‌1。

  • 冒泡排序的算法原理

                      冒泡排序的核心思想是从待排序的元素中逐个比较相邻的两个元素,如果它们的顺序不符合要求(例如升序排序时,前一个元素大于后一个元素),则交换它们的位置。这个过程可以类比水中的冒泡现象,大的元素会逐渐“浮”到数组的末尾,而小的元素则会“沉”到数组的前面‌。

4,数组的三种初始化方式是什么?

  • 静态初始化

是在声明数组的同时直接为数组元素分配空间并赋值。

  • 动态初始化

是将数组定义和为数组元素分配空间并赋值的操作分开进行。首先使用new关键字创建数组对象,但不立即赋值,之后再逐个赋值。

  • 默认初始化

是指数组在定义后,其元素会被隐式初始化为该类型的默认值。

public class Demo {public static void main(String[] args) {// 静态初始化int[] staticArray = {1, 2, 3, 4, 5};System.out.println(staticArray); // 输出: 1System.out.println(staticArray‌:ml-citation{ref="5" data="citationList"}); // 输出: 5// 动态初始化int[] dynamicArray = new int‌:ml-citation{ref="3" data="citationList"};dynamicArray = 1;dynamicArray‌:ml-citation{ref="1" data="citationList"} = 2;dynamicArray‌:ml-citation{ref="2" data="citationList"} = 3;dynamicArray‌:ml-citation{ref="4" data="citationList"} = 4;System.out.println(dynamicArray); // 输出: 1System.out.println(dynamicArray‌:ml-citation{ref="5" data="citationList"}); // 输出: 0(未赋值)// 默认初始化int[] defaultArray = new int‌:ml-citation{ref="3" data="citationList"};System.out.println(defaultArray); // 输出: 0(整数类型的默认值)}
}

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

猎板PCB2到10层数的科技进阶与应用解析

1. 单层板&#xff08;Single-sided PCB&#xff09; 定义&#xff1a;单层板是最基本的PCB类型&#xff0c;导线只出现在其中一面&#xff0c;因此被称为单面板。限制&#xff1a;由于只有一面可以布线&#xff0c;设计线路上有许多限制&#xff0c;不适合复杂电路。应用&…

2025年山东省考报名流程图解

2025年山东公务员考试备考开始 为大家整理了从笔试到录用的全部流程&#xff0c;希望可以帮助到你们&#xff01;参考2024年山东省考公告整理&#xff0c;请以最新公告为准&#xff01; 一、阅读公告和职位表 二、职位查询 三、网上报名 四、确认缴费 五、网上打印准考证 六、参…

修改elementUI等UI组件样式的5种方法总结,哪些情况需要使用/deep/, :deep()等方式来穿透方法大全

文章目录 方法 1:全局修改样式示例:修改 `ElMessage` 的背景色和字体颜色方法 2:修改特定类型的 `ElMessage` 样式-全局-不需要穿透示例:修改 `ElMessage` 成功类型的样式方法 3:通过 Scoped CSS 在组件内部修改-局部-不需要穿透方法 4:使用 JavaScript 动态修改样式-不需…

pandas——对齐运算+函数应用

引言&#xff1a;对齐运算是数据清洗的重要过程&#xff0c;可以按索引对齐进行运算&#xff0c;如果没对齐的位置则补NaN&#xff0c;最后也可以填充NaN 一、Series的对齐运算 1.Series 按行、索引对齐 import pandas as pds1 pd.Series(range(10, 20), indexrange(10)) s2…

# Ubuntu 达人九步养成记(1)

Ubuntu 达人九步养成记&#xff08;1&#xff09; 目录&#xff1a; 一、ubuntu基本安装 二、设置语言环境 三、设置服务器镜像源 四、在启动栏添加终端图标 五、使用apt更新和升级系统软件 六、使用apt安装软件 七、使用apt删除软件以及apt-get 八、deb格式及谷歌浏览…

优选算法第五讲:位运算模块

优选算法第五讲&#xff1a;位运算模块 1.常见的位运算总结2.判断字符是否唯一3.丢失的数字4.两整数之和5.只出现一次的数字II6.消失的两个数字 1.常见的位运算总结 2.判断字符是否唯一 链接: link class Solution { public:bool isUnique(string astr) {if(astr.size() >…

计算机视觉算法真的难学吗?这些技巧让你轻松掌握

在当今这个数字化迅猛发展的时代&#xff0c;计算机视觉作为人工智能的重要分支&#xff0c;正在逐渐改变我们的生活和工作方式。很多人可能会觉得计算机视觉算法难以掌握&#xff0c;尤其是在面对复杂的数学和编程时&#xff0c;常常会感到无从下手。不过&#xff0c;实际上&a…

基于YOLO11/v10/v8/v5深度学习的老鼠智能检测系统设计与实现【python源码+Pyqt5界面+数据集+训练代码】

《------往期经典推荐------》 一、AI应用软件开发实战专栏【链接】 项目名称项目名称1.【人脸识别与管理系统开发】2.【车牌识别与自动收费管理系统开发】3.【手势识别系统开发】4.【人脸面部活体检测系统开发】5.【图片风格快速迁移软件开发】6.【人脸表表情识别系统】7.【…

机器学习—前向传播的一般实现

可以写一个函数来实现一个密集的层&#xff0c;那是神经网络的单层&#xff0c;所以定义稠密函数&#xff0c;它将上一层的激活作为输入以及给定层神经元的参数w和b。看下边图片所展示的例子&#xff0c;把所有这些权重向量堆叠成一个矩阵&#xff0c;wnp.array([[1,-3,5][2,4,…

高清烟花视频素材下载网站推荐

无论是庆祝节日、婚礼&#xff0c;还是各种欢庆活动&#xff0c;烟花总能瞬间点燃气氛&#xff0c;带来视觉上的震撼。在视频作品中加入绚丽的烟花瞬间&#xff0c;能够立刻提升画面的冲击力和节庆氛围。那么&#xff0c;高清烟花视频素材去哪下载呢&#xff1f;今天&#xff0…

Java异常体系结构

在Java编程中&#xff0c;异常处理是一个重要的概念。理解Java的异常体系结构以及如何捕获和处理异常&#xff0c;对于编写健壮的程序至关重要。本文将详细介绍Java异常体系结构的组成部分&#xff0c;以及异常的捕获和处理机制。 一、Java异常体系结构 Java的异常体系结构可以…

免费,基于React + ECharts 国产开源 IoT 物联网 Web 可视化数据大屏

文末查看开源项目地址 Light Chaser 是一款国产开源免费的基于 React18、Vite5、TypeScript5 技术栈实现的 Web 可视化大屏设计工具&#xff0c;支持Docker方式部署&#xff0c;支持MySQL、PostgreSQL、SQL Server、Oracle 数据源。 你可以简单快速地搭建数据可视化展示、数据报…

【解决】Pico 串流 Unity 开发环境 Preview 黑屏问题

开发平台&#xff1a;Unity 6.0 开发工具&#xff1a;Pico SDK   一、问题描述 在 Unity 开发环境下运行 测试 PicoVR 表现时&#xff0c;出现 Game视窗 PicoVR投屏 呈现黑屏效果。详细背景如下&#xff1a; UnitySwitch PlateformPICO Integration SDKPICO Live Preview6…

pytest高版本兼容test_data[“log“] = _handle_ansi(“\n“.join(logs))错误

一、问题现象&#xff1a; 执行seleniumpytest结束时报: INTERNALERROR> File "D:\workspace\pytestframe\.venv\Lib\site-packages\pytest_html\report_data.py", line 141, in add_test INTERNALERROR> test_data["log"] _handle_ansi(&q…

编译工具与文件学习(一)-YAML、repos、vcstoolcolcon

YAML YAML&#xff08;YAML Ain’t Markup Language&#xff09;是一种人类可读的数据序列化格式&#xff0c;常用于配置文件、数据交换和存储结构化数据。YAML 的设计目标是简洁、易读&#xff0c;并且能够表示复杂的数据结构。 YAML 文件的基本语法 基本结构&#xff1a; Y…

信息学科平台系统构建:Spring Boot框架深度解析

4系统概要设计 4.1概述 本系统采用B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式&#xff0c;是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在任何时间、任何地点使用。系统工作原理图如图4-1所示&#xff1a; 图4-1系统工作原理…

从传统服务器到虚拟化:虚拟机 VM 如何改变计算游戏规则?

目录 VMware 数据中心虚拟化入门Ⅰ—— 虚拟机 Virtual Machine&#xff08;VM&#xff09;1. 虚拟机 Virtual Machine, VM阅读本文后可以获得以下信息1.1 什么是虚拟机问题思考&#xff08;1&#xff09;从传统服务器到虚拟化服务器&#xff08;2&#xff09;问题&#xff1a;…

双向链表及如何使用GLib的GList实现双向链表

双向链表是一种比单向链表更为灵活的数据结构&#xff0c;与单向链表相比可以有更多的应用场景&#xff0c;本文讨论双向链表的基本概念及实现方法&#xff0c;并着重介绍使用GLib的GList实现单向链表的方法及步骤&#xff0c;本文给出了多个实际范例源代码&#xff0c;旨在帮助…

MySQL 数据库之库操作

文章目录 1. 什么是数据库2. 基础概念2.1 连接数据库2.2 服务器&#xff0c;数据库&#xff0c;表关系2.3 SQL分类 3. 库的操作3.1 创建&#xff0c;选择&#xff0c;查看数据库3.2 字符集和默认校验规则 3.3 操纵数据库3.3.1 数据库查看3.3.2 数据库删除3.3.3 数据库修改 4. 其…

Windows安装多个NodeJS版本

下载nvm管理工具&#xff0c;下载完成解压安装 https://github.com/coreybutler/nvm-windows/releases 选择nvm安装位置 选择nvm安装node版本的安装位置 如果提示你已经安装的有nodejs&#xff0c;提示你是否通过nvm管理nodejs&#xff0c;选择是&#xff0c;继续安装即可…