一、数组概念

一、数组定义

数组就是指在计算机内存中开辟的连续存储空间,用于存放程序运行中需要用到的一组相同类型数据的容器。

二.数组的声明 +数组的长度

定义数组时需要确定数组的长度(元素的个数),确定后不能更改;

获取数组长度:数组名.length

1. 格式1(默认初始值)

  • 数据类型 [ ] 数组名 = new 数据类型 [ 数组的个数 ]

    例:int [ ] money = new int [ 100 ];

    数组长度:money.length(100);

2.格式2(赋予初始值)

  • 数据类型 [ ] 数组名 = new 数据类型 [ ]

    例:int [ ] money = new int [ ]{100,200,300,...n};

    数组长度:money.length(n);

3.格式3(格式2简写)

  • 数据类型 [ ] 数组名 =

​ 例:int [ ] money = {100,200,300};

​ 数组长度:money.length(3);

三、数组的访问

例:

int [ ] money = new int [ 100 ]; //声明一个包含100个元素的数组

访问第一个元素(数组下标索引从0开始)

money[ 0 ] = 100;

访问第二个元素

money [ 1 ] =200;

​ ...

访问第100个元素

money [ 99 ] = 1000;

访问第101 个元素(数组下越界异常,数组越界,不会显示编译错误,而是运行时报错)

money[ 100 ]= 1100;

四、数组的遍历

例:

int [] arr = new int [6];
for(index = 0;index < arr.index.length;index++){
System.out.println(arr[index])
}

五、数组的特点

1.数组长度一旦指定,就无法更改;

2.数组一旦声明类型后,数组中只能存放同一类型的数据数组;

3.数组类型可以是任何数据类型,包括基本类型和引用类型;

数组有索引:从零开始,到数组.length-1结束。

六、数组的缺点

1.数组长度指定后,就不能更改;

2.删除、添加元素效率低;

3.数组中实际元素的数量没办法获取,没有提供对应的方法或属性来获取;

七、实例

/**
* @author yeye
* @desc 数组访问示例
* @date 2024
*/
public class ArrayVisitDemo {
public static void main(String[] args) {
int [] arr = new int [5];
arr [0] = 1;
arr [1] = 2;
arr [2] = 3;
arr [3] = 4;
arr [4] = 5;
// arr [5] = 6;//数组越界,不会显示编译错误,而是运行时报错
System.out.println("数组的长度是:"+arr.length);
//数组遍历
for(int index = 0;index <arr.length;index++){
System.out.println(arr[index]);
}
System.out.println("数组元素为:"+arr[0]+" "+arr[1]+" "+arr[2]+" "+arr[3]+" "+arr[4]);
}
}

二、一维数组和二维数组

一、一维数组定义

数组中每个元素都只带一个下标,这样的数组称为一维数组。使用Java数组前,应声明数组并为数组分配存储空间。

二、声明一维数组

1.类型标识符 [ ] 数组名 =null; 例:

int [ ] list = null; //声明list为一维类型数组

2.类型标识符 数组名 [ ] = null;例:

int list [ ] = null; //声明list为一维类型数组

三、初始化一维数组

1.通过直接指定初值来初始化数组,例:

int [ ] list = {1,2,3};

2.利用new关键字初始化

利用new 关键字初始化数组,不仅能为数组分配需要的存储空间,还能按照Java的默认初始化原则为数组元素赋值。

四、二维数组

例:int money [ ] = new int [3] [12];

二维数组的遍历

int money [ ] = new int [3] [12];

for(int row = 0;row <3;++row){
for(int column = 0;column<13;++column){
money[row][column] =100;
}
}

三、数组的算法(冒泡排序法)

口诀 :

冒泡排序要知道;内外循环两层套;外环数组遍历到;内环边界计算好;左右元素判大小;临时变量交换好。

//外层循环遍历整个数组(最后一个数组不需要遍历)
for(i = 0;i < (数组长度-1);i++){
//内存循环控制元素交换即冒泡,一般为数组长度-外层循环遍历-1
for(j = 0;j <(数组长度-i-1);j++){
//升序--如果前面大于后面则交换;降序--如果后面大于前面则交换
if(array[j] > array[j+1]){
//引进temp变量作为交换媒介
int temp = array[j+1]; //临时变量
array[j+1] = array[j];
array[j] = temp;
}
} }

实例:

package array;

/**
* @author yeye
* @desc 冒泡排序法
* @date 2024
*/
public class BubbleSortDemo {
public static void main(String[] args) {
// 定义数组
int[] arr =new int [] {3,2,5,8,6,1,4,7};
//冒泡排序
for(int i = 0;i < arr.length;i++){
for(int j =0;j <arr.length-i-1;j++){
if(arr[j] > arr[j+1] ){
int temp = arr[j+1];
arr[j+1] = arr[j];
arr[j] = temp;
}
}
}
// 输出排序后的数组
for(int i = 0;i < arr.length;i++){
System.out.print(arr[i]);
}
}
}

Java数组小白版的更多相关文章

  1. 《Effective Java(中文第二版)》【PDF】下载

    <Effective Java(中文第二版)>[PDF]下载链接: https://u253469.pipipan.com/fs/253469-230382186 Java(中文第二版)& ...

  2. 《Effective Java中文版第二版》读书笔记

    说明 这里是阅读<Effective Java中文版第二版>的读书笔记,这里会记录一些个人感觉稍微有些重要的内容,方便以后查阅,可能会因为个人实力原因导致理解有误,若有发现欢迎指出.一些个 ...

  3. java数组知识总结(一)//按类

    在线api  目录: 零/数组(基本元素) 1.  声明一个数组 2.  创建一个数组 3.  数组名.length 4.  数组的引用 一/java.lang.reflect.Array     / ...

  4. Java 数组

    数组对于每一门编程语言来说都是重要的数据结构之一,当然不同语言对数组的实现及处理也不尽相同. Java语言中提供的数组是用来存储固定大小的同类型元素. 你可以声明一个数组变量,如numbers[100 ...

  5. 第5章 Java数组

    1.什么是数组 数组可以想象成一个巨大的盒子,这个盒子里面存放的是同一个数据类型的数据 例如:int[] scores = {78,68,94,93}; 2.如何使用Java中的数组 2.1申明数组 ...

  6. Java 数组基础

    数组 数组(Array):相同类型数据的集合. 定义数组 方式1(推荐,更能表明数组类型) type[] 变量名 = new type[数组中元素的个数]; 比如: int[] a = new int ...

  7. Java数组及其内存分配

    几乎所有的程序设计语言都支持数组.Java也不例外.当我们需要多个类型相同的变量的时候,就考虑定义一个数组.在Java中,数组变量是引用类型的变量,同时因为Java是典型的静态语言,因此它的数组也是静 ...

  8. [转载]Java数组扩容算法及Java对它的应用

    原文链接:http://www.cnblogs.com/gw811/archive/2012/10/07/2714252.html Java数组扩容的原理 1)Java数组对象的大小是固定不变的,数组 ...

  9. Java数组技巧攻略

      Java数组技巧攻略 0.  声明一个数组(Declare an array) String[] aArray = new String[5]; String[] bArray = {" ...

  10. Java数组扩容算法及Java对它的应用

    1)Java数组对象的大小是固定不变的,数组对象是不可扩容的.利用数组复制方法可以变通的实现数组扩容.System.arraycopy()可以复制数组.Arrays.copyOf()可以简便的创建数组 ...

随机推荐

  1. 从JDK8升级到JDK17

    一.概述 鉴于JDK8已经是老古董,还有性能问题,兼且各个公司已经不再维护1.8的JDK,所以升级公司的核心产品之一的后端到JDK到17是相对要紧的事情. 通过升级到jdk17,具有以下好处: 不要在 ...

  2. 【ZeroMQ】zguide 第一章 部分翻译

    为了更好的阅读体验,请点击这里 本文大部分内容翻译自 Chapter 1 - Basics,原因是之前翻译的版本太老了,不得不亲自披挂上阵拿机器翻译一下.只截取了部分自己可能用得到的,所以如果有看不太 ...

  3. Linux内核:regmap机制

    背景 在学习SPI框架的时候,看到了有一个rtc驱动用到了regmap,本想通过传统方式访问spi接口的我,突然有点不适应,翻了整个驱动,愣是没有找到读写spi的范式:因此了解了regmap以后,才发 ...

  4. 高通安卓:自定义QFile烧录镜像

    高通安卓:自定义QFile烧录镜像 背景 在某个项目中,因为USB口的问题,无法使用fastboot进行download. 同事提供了一份用与QFile的rawprogram.xml烧写.觉得这个方法 ...

  5. arm linux 移植 SQLite 3

    背景 SQLite 是 一个 常用于 嵌入式平台的 轻量级数据库. host平台 :Ubuntu 16.04 arm平台 : S5P6818 SQLite :3.31.1 arm-gcc :4.8.1 ...

  6. 基于 UDP 的 组播、广播详解

    背景 有些时候我们在网络通信中也需要用到 组播(多播).广播.现在我们来介绍如何实现. 建议:在此之前,关闭防火墙. ubuntu: service ufw stop windows: 控制面板关闭 ...

  7. BigCodeBench: 继 HumanEval 之后的新一代代码生成测试基准

    HumanEval 是一个用于评估大型语言模型 (LLM) 在代码生成任务中的参考基准,因为它使得对紧凑的函数级代码片段的评估变得容易.然而,关于其在评估 LLM 编程能力方面的有效性越来越多的担忧, ...

  8. GUI测试稳定性的关键技术

    标签(空格分隔): GUI测试稳定性 GUI测试稳定性的关键技术 GUI 自动化测试稳定性,最典型的表现形式就是,同样的测试用例在同样的环境上,时而测试通过,时而测试失败. 这也是影响 GUI 测试健 ...

  9. 工控CTF_Modbus TCP

    工控CTF_Modbus TCP 参考文章 https://blog.csdn.net/song123sh/article/details/128387982 https://www.anquanke ...

  10. 合合TextIn - 大模型加速器

    TextIn是合合信息旗下的智能文档处理平台,在智能文字识别领域深耕17年,致力于图像处理.模式识别.神经网络.深度学习.STR.NLP.知识图谱等人工智能领域研究.凭借行业领先的技术实力,为扫描全能 ...