当前位置: 首页 > news >正文

【Java】数组

目录

1.数组的定义与初始化

2.遍历数组

3.认识null

4.引用变量

5.返回多个值

6.数组拷贝

7.数组逆序 

8.数组填充

9.小练习

//将整形数组转化为字符串

//二分查找优化

//冒泡排序优化

10.二维数组

//遍历二维数组 

//不规则的二维数组


1.数组的定义与初始化

int [ ] arr1 = { 0, 1, 2, 3, 4};

int [ ] arr2 = new int [ ]{ 0, 1, 2, 3, 4};

int [ ] arr3 = new int [5];

注意:1> 不同于C语言中未初始化默认为随机值,Java中未初始化默认为0

           2> 当需要整体初始化时,必须在定义的时候初始化,即不能先定义再初始化

           3> 第二点中用上述arr3中的new方式可以先定义再初始化,但是需要分开初始化;

           4> boolean类型数组默认值为false,string类型数组默认值为null(注意是小写)。

2.遍历数组

public static void main(String[] args) {int[] arr = {1, 2, 3, 4, 5};//法一//获取长度:遍历对象.length for(int i = 0;i< arr.length;i++){System.out.print(arr[i]);}System.out.println();//法二:for-each,增强for循环//把arr中的每个元素都取出来放到x里面//与for循环区别:无法获取数组下标for (int x:arr) {System.out.print(x+" ");}System.out.println();//法三:要导入import java.util.Arrays;//Java自己将数组里的值以字符串形式组织后进行打印System.out.println(Arrays.toString(arr));
}

 

这里使用了Java自带的方法打印字符串 Array.toString(),顺便说一下排序方法 Array.sort()

这类方法还有很多,之后碰见了再一一叙述(下方二分查找中就有另一种方法)。

 

3.认识null

public static void main(String[] args) {int[] arr = null;//arr这个引用,不指向任何对象System.out.println(arr.length);//空指针异常System.out.println(arr[0]);//空指针异常
}

 null在Java中表示“空引用”,也就是一个不指向对象的引用,作用类似于C语言中的NULL(空指针)

4.引用变量

public static void main(String[] args) {int[] arr1 = {1,2,3,4,5};int[] arr2 = arr1;arr2[0] = 9;System.out.println(Arrays.toString(arr1));//[9, 2, 3, 4, 5]System.out.println(Arrays.toString(arr2));//[9, 2, 3, 4, 5]
}

 arr2这个引用指向了arr1这个引用所指向的对象,即arr1和arr2指向同一内存,修改其中任何一个引用另一个也会被修改。

5.返回多个值

public static int[] fun1(){int[] arr = new int[]{1,2,3,4,5};return arr;
}
public static int[] fun2(){int a = 10;int b = 20;return new int[]{a,b};
}
public static void main(String[] args) {int[] ret1 = fun1();int[] ret2 = fun2();System.out.println(Arrays.toString(ret1));//[1, 2, 3, 4, 5]System.out.println(Arrays.toString(ret2));//[10, 20]
}

6.数组拷贝

public static int[] copy(int[] arr){int[] copyArr = new int[arr.length];for (int i = 0; i < arr.length; i++) {copyArr[i] = arr[i];}return copyArr;
}
public static void main(String[] args) {int[] arr = {1,2,3,4,5};//法一:自己实现int[] ret1 = copy(arr);System.out.println(Arrays.toString(ret1));//[1, 2, 3, 4, 5]//法二:Java自带int[] ret2 = Arrays.copyOf(arr,arr.length);System.out.println(Arrays.toString(ret2));//[1, 2, 3, 4, 5]数组扩容int[] ret3 = Arrays.copyOf(arr,arr.length*2);System.out.println(Arrays.toString(ret3));//[1, 2, 3, 4, 5, 0, 0, 0, 0, 0]指定范围拷贝:Arrays.copyOfRange()int[] ret4 = Arrays.copyOfRange(arr,1,4);//注意:[1,4),左闭右开System.out.println(Arrays.toString(ret4));//[2, 3, 4]指定范围拷贝:System.arraycopy()int[] ret5 = new int[arr.length];System.arraycopy(arr,0,ret5,0,arr.length);//拷贝arr.length个元素从arr的0下标处到ret5的0下标处System.out.println(Arrays.toString(ret5));//[1, 2, 3, 4, 5]
}

7.数组逆序 

这个与C语言没有什么区别。

public static void reverse(int[] arr){int i = 0;int j = arr.length-1;while(i < j){int tmp = arr[i];arr[i] = arr[j];arr[j] = tmp;i++;j--;}
}
public static void main(String[] args) {int[] arr = {1,2,3,4,5,};reverse(arr);System.out.println(Arrays.toString(arr));
}

8.数组填充

public static void main(String[] args) {int[] arr1 = new int[5];int[] arr2 = new int[5];Arrays.fill(arr1,6);//全部填充为6Arrays.fill(arr2,1,3,8);//[1,3)填充为8System.out.println(Arrays.toString(arr1));//[6, 6, 6, 6, 6]System.out.println(Arrays.toString(arr2));//[0, 8, 8, 0, 0]
}

9.小练习

//将整形数组转化为字符串

public static String toString(int[] arr){if(arr == null){return null;}String ret = "[";int i = 0;for (i = 0; i < arr.length-1; i++) {ret += arr[i];ret += ",";}ret += arr[i];ret += "]";return ret;
}
public static void main(String[] args) {int[] arr = {1,2,3,4,5};String ret = toString(arr);System.out.println(ret);//[1,2,3,4,5]
}

//二分查找优化

public static int findkey(int[] arr,int key){int left = 0;int right = arr.length;while(left <= right){int mid = (left + right)/2;if(arr[mid] > key){right = mid - 1;}else if(arr[mid] < key){left = mid + 1;}else{return mid;}}return -1;
}
public static void main(String[] args) {int[] arr = {0,1,2,3,4,5,6,7,8,9};Scanner scan = new Scanner(System.in);int key = scan.nextInt();//法一:自己实现int ret = findkey(arr,key);System.out.println(ret);//法二:Java自带 Arrays.binarySearchint index = Arrays.binarySearch(arr,key);System.out.println(index);
}

二分查找只能用于有序数组,但有了 Array.sortArray.binarySearch 后,先排序再查找,这样不论是有序还是无序数组都可以查找了,超级方便!! 

//冒泡排序优化

public static void bubbleSort (int[] arr){for (int i = 0; i < arr.length-1; i++) {boolean flag = false;for (int j = 0; j < arr.length-1-i; j++) {if(arr[j] > arr[j+1]){int tmp = arr[j];arr[j] = arr[j+1];arr[j+1] = tmp;flag = true;}}//当内层循环发现数组已经有序时,flag为falseif(flag == false){break;}}
}
public static void main(String[] args) {int[] arr = {0,2,4,6,8,1,3,5,7,9};bubbleSort(arr);System.out.println(Arrays.toString(arr));
}

相较于之前的冒泡排序,这里增加了flag作为标记,如果内层循环发现数组已经有序,flag就会置为true并且跳出循环,之后的循环就没必要进行了,节省时间。

10.二维数组

定义:int[][] arr1 = {{1,2,3},{4,5,6}};int[][] arr2 = new int[2][3];int[][] arr3 = new int[][]{{1,2,3},{1,2,3}};

//遍历二维数组 

public static void main(String[] args) {int[][] arr = {{1,2,3},{4,5,6}};System.out.println(arr.length);//2System.out.println(arr[1].length);//3//法一:for循环for (int i = 0; i < arr.length; i++) {for (int j = 0; j < arr[i].length; j++) {System.out.print(arr[i][j]+" ");}System.out.println();}//法二:for-each循环for (int[] x:arr) {for (int y:x) {System.out.print(y+" ");}System.out.println();}//法三:Arrays.deepToString()String ret = Arrays.deepToString(arr);System.out.println(ret);//[[1, 2, 3], [4, 5, 6]]
}

//不规则的二维数组

Java中不可省略行,但可省略列

这样一来二维数组就变得十分灵活,可以自定义每一行的列数。

public static void main(String[] args) {int[][] arr = new int[2][];arr[0] = new int[3];//第一行列数为3arr[1] = new int[5];//第二行列数为5
}

相关文章:

【Java】数组

目录 1.数组的定义与初始化 2.遍历数组 3.认识null 4.引用变量 5.返回多个值 6.数组拷贝 7.数组逆序 8.数组填充 9.小练习 //将整形数组转化为字符串 //二分查找优化 //冒泡排序优化 10.二维数组 //遍历二维数组 //不规则的二维数组 1.数组的定义与初始化 int…...

【C++】非类型的模板参数,特化

目录 1.类型模板参数和非类型模板参数 2.特化 3. 模板的分离编译 4.模板的优缺点 1.类型模板参数和非类型模板参数 之前写模板传的都是类型——类型模板参数 现在想定义两个静态数组&#xff0c;数组长度不同&#xff0c;就可以用模板参数传数值而不是传类型 非类型模板…...

核方法(kernel Method)

核方法 核方法定义 一种能够将在原始数据空间中的非线性数据映射到高维线性可分的方法。 核方法的用处 1、低维数据非线性&#xff0c;当其映射到高维空间&#xff08;feature space&#xff09;时&#xff0c;可以用线性方法对数据进行处理。 2、线性学习器相对于非线性学…...

消息队列MQ用来做什么的,市场上主流的四大MQ如何选择?RabbitMQ带你HelloWorld!

文章目录MQ用来做什么的MQ会有什么样的麻烦MQ消息队列模式分类MQ消息队列常用协议市场主流四大MQRabbitMQ项目开发RabbitMQ中的组成部分MQ用来做什么的 省流 &#xff1a;系统解耦、异步调用、流量削峰 系统解耦 首先举例下面这个场景&#xff0c;现有ABCDE五个系统&#xff…...

2023年中国高校计算机大赛-团队程序设计天梯赛(GPLT)上海理工大学校内选拔赛(同步赛) A — E

2023年中国高校计算机大赛-团队程序设计天梯赛&#xff08;GPLT&#xff09;上海理工大学校内选拔赛&#xff08;同步赛) 文章目录A -- A Xor B Problem题目分析codeB -- 吃苹果题目分析codeC -- n皇后问题题目分析codeD -- 分苹果题目分析codeE -- 完型填空题目分析codeA – A…...

一文分析Linux v4l2框架

说明&#xff1a; Kernel版本&#xff1a;4.14 ARM64处理器&#xff0c;Contex-A53&#xff0c;双核 使用工具&#xff1a;Source Insight 3.5&#xff0c; Visio 1. 概述 V4L2(Video for Linux 2)&#xff1a;Linux内核中关于视频设备驱动的框架&#xff0c;对上向应用层提供…...

MFC常用控件使用(文本框、编辑框、下拉框、列表控件、树控件)

简介 本文章主要介绍下MFC常用控件的使用&#xff0c;包括静态文本框(Static Text)、编辑框(Edit Control)、下拉框(Combo Box)、列表控件(List Control)、树控件(Tree Control)的使用。 创建项目 我们选择 文件->新建->新建项目&#xff0c;选择MFC程序 选择基于对话…...

13 node 程序后台执行加上 tail 命令, 中断 tail 命令, 同时也中断了 node 程序

前言 呵呵 最近帮朋友解决问题[2022.09.08] 需要启动一个 node 程序, 然后 需要一个 startUp.sh 脚本 然后 反手写了一个过去, 按道理 来说 应该是 后台启动了对应的 node 程序, 然后将 标准输出, 错误输出 输出到 logs/nohup.log 日志文件中, 然后基于 tail 命令 来查看 …...

52癫痫发作预测的有效双自注意力残差网络

Effective dual self-attentional residual networks for epileptic seizure prediction 摘要 癫痫发作预测作为慢性脑疾病中最具挑战性的数据分析任务之一&#xff0c;引起了众多研究者的广泛关注。癫痫发作预测&#xff0c;可以在许多方面大大提高患者的生活质量&#xff0…...

【计算机网络】Tcp IP 面试题相关

互联网协议群&#xff08;TCP/IP&#xff09;&#xff1a;多路复用是怎么回事&#xff1f; 1.【问题】IPv4 和 IPv6 有什么区别&#xff1f; IPv4 是用 32 位描述 IP 地址&#xff0c;理论极限约在 40 亿 IP 地址&#xff1b; IPv6 是用 128 位描述 IP 地址&#xff0c;IPv6 可…...

【MySQL】MySQL的存储引擎

目录 概念 分类 操作 概念 数据库存储引擎是数据库底层软件组织&#xff0c;数据库管理系统&#xff08;DBMS&#xff09;使用数据引擎进行创建、查 询、更新和删除数据。 不同的存储引擎提供不同的存储机制、索引技巧、锁定水平等功能。现在 许多不同的数据库管理系统…...

es6动态模块import()

目录 一、语法说明 二、适用场合 三、注意点 四、示例代码 五、效果 一、语法说明 import命令会被 JavaScript 引擎静态分析&#xff0c;先于模块内的其他语句执行&#xff08;import命令叫做“连接” binding 其实更合适&#xff09;。 // 报错 if (x 2) {import MyMod…...

【Flask】Jinja2模板(十四)

Jinja2是一个单独的Python包&#xff0c;Flask依赖Jinja2&#xff0c;安装Flask时会自动安装Jinja2。Jinja2可以将数据和模板结合在一起生成动态文本。 一、引入 来看一个最简单的视图函数&#xff1a; app.route(/) def hello_world():return Hello World&#xff01; 这个…...

Mr. Cappuccino的第49杯咖啡——冒泡APP(升级版)之基于Docker部署Gitlab

冒泡APP&#xff08;升级版&#xff09;之基于Docker部署Gitlab基于Docker安装Gitlab登录Gitlab创建Git项目上传代码使用Git命令切换Git地址使用IDE更换Git地址基于Docker安装Gitlab 查看beginor/gitlab-ce镜像版本 下载指定版本的镜像 docker pull beginor/gitlab-ce:11.3.0…...

《机器学习》基础概念之【P问题】与【NP问题】

《机器学习》基础概念之【P问题】与【NP问题】 这里写目录标题《机器学习》基础概念之【P问题】与【NP问题】一、多项式&时间复杂度1.1. 多项式1.2.时间复杂度二、P问题 & NP问题2.1. P问题2.2.NP问题2.3.举例理解NP问题-TSP旅行商推销问题三、NP-hard问题&NP-C问题…...

WinRAR安装教程

文章目录WinRAR安装教程无广告1. 下载2. 安装3. 注册4. 去广告WinRAR安装教程无广告 1. 下载 国内官网&#xff1a;https://www.winrar.com.cn/ 2. 安装 双击&#xff0c;使用默认路径&#xff1a; 点击“安装”。 点击“确定”。 点击“完成”。 3. 注册 链接&#xff…...

C++:vector和list的迭代器区别和常见迭代器失效问题

迭代器常见问题的汇总vector迭代器和list迭代器的使用vector迭代器list迭代器vector迭代器失效问题list迭代器失效问题vector和list的区别vector迭代器和list迭代器的使用 学习C&#xff0c;使用迭代器和了解迭代器失效的原因是每个初学者都需要掌握的&#xff0c;接下来我们就…...

SpringSecurity如何实现前后端分离

前后端分离模式是指由前端控制页面路由&#xff0c;后端接口也不再返回html数据&#xff0c;而是直接返回业务数据&#xff0c;数据一般是JSON格式。Spring Security默认的表单登录方式&#xff0c;在未登录或登录成功时会发起页面重定向&#xff0c;在提交登录数据时&#xff…...

为ubuntu 18.04添加蓝牙驱动

目录背景方法背景 从网上买的能直接插ubuntu 1804的usb蓝牙太少了&#xff0c;而且还贵。我就直接从JD下单的一个便宜的USB蓝牙&#xff0c;结果插上机器没有驱动起不来。我的PC是个3年前的老机器&#xff0c;实在是不想升级系统&#xff0c;于是捣鼓半天捣鼓好了&#xff0c;…...

Stable Diffusion Prompt用法

Stable Diffusion可以根据你输入的提示词&#xff08;prompt&#xff09;来绘制出想象中的画面。 1、正向提示词&#xff08;Prompt&#xff09;&#xff1a; 提高图像质量的prompt: prompt用途HDR, UHD, 64K(HDR、UHD、4K、8K和64K)这样的质量词可以带来巨大的差异提升照片…...

SciencePlots——绘制论文中的图片

文章目录 安装一、风格二、1 资源 安装 # 安装最新版 pip install githttps://github.com/garrettj403/SciencePlots.git# 安装稳定版 pip install SciencePlots一、风格 简单好用的深度学习论文绘图专用工具包–Science Plot 二、 1 资源 论文绘图神器来了&#xff1a;一行…...

Opencv中的addweighted函数

一.addweighted函数作用 addweighted&#xff08;&#xff09;是OpenCV库中用于图像处理的函数&#xff0c;主要功能是将两个输入图像&#xff08;尺寸和类型相同&#xff09;按照指定的权重进行加权叠加&#xff08;图像融合&#xff09;&#xff0c;并添加一个标量值&#x…...

【快手拥抱开源】通过快手团队开源的 KwaiCoder-AutoThink-preview 解锁大语言模型的潜力

引言&#xff1a; 在人工智能快速发展的浪潮中&#xff0c;快手Kwaipilot团队推出的 KwaiCoder-AutoThink-preview 具有里程碑意义——这是首个公开的AutoThink大语言模型&#xff08;LLM&#xff09;。该模型代表着该领域的重大突破&#xff0c;通过独特方式融合思考与非思考…...

【SQL学习笔记1】增删改查+多表连接全解析(内附SQL免费在线练习工具)

可以使用Sqliteviz这个网站免费编写sql语句&#xff0c;它能够让用户直接在浏览器内练习SQL的语法&#xff0c;不需要安装任何软件。 链接如下&#xff1a; sqliteviz 注意&#xff1a; 在转写SQL语法时&#xff0c;关键字之间有一个特定的顺序&#xff0c;这个顺序会影响到…...

html css js网页制作成品——HTML+CSS榴莲商城网页设计(4页)附源码

目录 一、&#x1f468;‍&#x1f393;网站题目 二、✍️网站描述 三、&#x1f4da;网站介绍 四、&#x1f310;网站效果 五、&#x1fa93; 代码实现 &#x1f9f1;HTML 六、&#x1f947; 如何让学习不再盲目 七、&#x1f381;更多干货 一、&#x1f468;‍&#x1f…...

Python基于历史模拟方法实现投资组合风险管理的VaR与ES模型项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档&#xff09;&#xff0c;如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 在金融市场日益复杂和波动加剧的背景下&#xff0c;风险管理成为金融机构和个人投资者关注的核心议题之一。VaR&…...

免费数学几何作图web平台

光锐软件免费数学工具&#xff0c;maths,数学制图&#xff0c;数学作图&#xff0c;几何作图&#xff0c;几何&#xff0c;AR开发,AR教育,增强现实,软件公司,XR,MR,VR,虚拟仿真,虚拟现实,混合现实,教育科技产品,职业模拟培训,高保真VR场景,结构互动课件,元宇宙http://xaglare.c…...

Caliper 负载(Workload)详细解析

Caliper 负载(Workload)详细解析 负载(Workload)是 Caliper 性能测试的核心部分,它定义了测试期间要执行的具体合约调用行为和交易模式。下面我将全面深入地讲解负载的各个方面。 一、负载模块基本结构 一个典型的负载模块(如 workload.js)包含以下基本结构: use strict;/…...

pikachu靶场通关笔记19 SQL注入02-字符型注入(GET)

目录 一、SQL注入 二、字符型SQL注入 三、字符型注入与数字型注入 四、源码分析 五、渗透实战 1、渗透准备 2、SQL注入探测 &#xff08;1&#xff09;输入单引号 &#xff08;2&#xff09;万能注入语句 3、获取回显列orderby 4、获取数据库名database 5、获取表名…...

嵌入式常见 CPU 架构

架构类型架构厂商芯片厂商典型芯片特点与应用场景PICRISC (8/16 位)MicrochipMicrochipPIC16F877A、PIC18F4550简化指令集&#xff0c;单周期执行&#xff1b;低功耗、CIP 独立外设&#xff1b;用于家电、小电机控制、安防面板等嵌入式场景8051CISC (8 位)Intel&#xff08;原始…...