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

[Java · 铢积寸累] 数据结构 — 数组类型 - 增 删 改 查

🌟 想系统化学习 Java 编程?看看这个:[编程基础] Java · 学习手册

在上一章中我们介绍了如何声明与创建数组,还介绍了数组的基本使用方式。本章我们将在上一章的基础上,拓展数组的使用方式(可能会涉及一些思维题)。

0x01:数组的应用 — 遍历数组元素

0x0101:普通 for 循环遍历数组元素

使用 for 循环结合数组的 length 属性,我们可以很轻松的打印数组的每个元素:

public class TestVar {public static void main(String[] args) {int[] arr = {10, 20, 30, 40};
​for (int i = 0; i < arr.length; i++) {System.out.println("arr 数组的第 " + i + " 个元素: " + arr[i]);}}
}

0x0102:增强 for 循环遍历数组元素

除了普通 for 循环,对于数组,我们还可以使用增强 for 循环来简单的遍历数组的元素内容。只不过此时我们无法使用跟索引有关的操作:

public class TestVar {public static void main(String[] args) {int[] arr = {10, 20, 30, 40};
​// 对 arr 数组进行遍历,遍历出来的每个元素都用 int 型的 num 接收int index = 1; // 数组当前的下标for (int num : arr) {System.out.println("arr 数组的第 " + index + " 个元素: " + num);index++;}}
}

0x02:数组的应用 — 数组最值问题

0x0201:引用类型 — 地址传递

在前面的章节中,我们介绍了方法,说 Java 是 值传递 。但那个时候说法其实是不完全的,这里补全一下:

  • 如果使用的是基本数据类型: 那么传递的就是字面值。

  • 如果使用的是引用数据类型: 那么传递的就是地址值。

好巧不巧,我们数组,就是一个引用数据类型。看下面这个例子(我们在函数中的修改,也将影响到主函数中数组的内容):

public class TestVar {public static void main(String[] args) {int[] arr = {10, 20, 30, 40};
​changeArryLast(arr); // 调用方法// 对 arr 数组进行遍历,遍历出来的每个元素都用 int 型的 num 接收int index = 1; // 数组当前的下标for (int num : arr) {System.out.println("arr 数组的第 " + index + " 个元素: " + num);index++;}}
​public static void changeArryLast(int[] arr) {// 改变数组最后一位的值为 17arr[arr.length - 1] = 17;}
}

0x0202:求数组中的最小值

现在有这个一个需求,给定一个 int 型数组 {10, 17, 14, 16, 20, 4} 求出数组的最小值。你能用什么方法完成这个需求?笔者这里直接上代码了哈(其实就是打擂台,谁小,谁就站得住):

public class TestVar {public static void main(String[] args) {int[] arr = {10, 17, 14, 16, 20, 4};int min = getMinNumber(arr);System.out.println("数组中的最小值为: " + min);}
​public static int getMinNumber(int[] arr) {int min = arr[0]; // 假设数组第 0 个值为最小值for (int num : arr) {if (min > num) { // 如果最小值比当前的值大,就把最小值赋给 minmin = num;}}return min; // 返回最小值}
}

0x0203:求数组中的最大值

继续,给定一个 int 型数组 {10, 17, 14, 16, 20, 4} 求出数组的最大值:

public class TestVar {public static void main(String[] args) {int[] arr = {10, 17, 14, 16, 20, 4};int min = getMaxNumber(arr);System.out.println("数组中的最大值为: " + min);}
​public static int getMaxNumber(int[] arr) {int max = arr[0]; // 假设数组第 0 个值为最大值for (int num : arr) {if (max < num) { // 如果最大值比当前的值小,就把最大值赋给 maxmax = num;}}return max; // 返回最小值}
}

0x03:数组的应用 — 数组查询问题

0x0301:查询问题 — 查询指定位置的元素

查询值定位置的元素,即根据提供的下标,获取数组中对应元素的值。这个最简单,直接上代码:

public class TestVar {public static void main(String[] args) {int[] arr = {10, 17, 14, 16, 20, 4};System.out.println("arr 中下标为 " + 2 + " 的元素的值是 " + getIndexValue(arr, 2));}
​public static int getIndexValue(int[] arr, int index) {// bug: 若 index < 0 或者 > length 咋办// 根据 index 的值返回 arr 中对应的值return arr[index];}
}

0x0302:查询问题 — 查询单个元素对应索引

有时候我们会有这么一个需求,即想根据一个值,查询这个值在数组中的索引是多少:

public class TestVar {public static void main(String[] args) {int[] arr = {10, 17, 14, 16, 20, 4};int index = getIndex(arr, 16); // 在 arr 中查询元素 16 的下标if (index == -1) {System.out.println("抱歉, arr 数组中查无此数");} else {System.out.println("arr 中元素 16 的下标为: " + index);}}
​/*查询数组指定元素对应的索引@arr : 待查询元素的数组@value: 待查询的元素值@return: 元素对应的索引下标 (int 型),若值为 -1 代表查询失败*/public static int getIndex(int[] arr, int value) {int index = -1;for (int i = 0; i < arr.length; i++) {if (arr[i] == value) { // 如果当前元素的值与待查询元素值相同,则返回元素下标return i;}}return index; // 否则返回 -1,代表未查询到}
}

0x04:数组的应用 — 元素添加问题

在使用数组时,我们经常会想往数组的一个指定位置添加元素。下面是一个示例代码:

import java.util.Scanner;
​
public class TestVar {public static void main(String[] args) {int[] arr = new int[5]; // 创建一个 5 个空间大小的数组
​// 为数组的前 4 个空格赋值arr[0] = 1;arr[1] = 2;arr[2] = 3;arr[3] = 4;
​// 获取用户想要插入的元素,和元素下标Scanner sc = new Scanner(System.in);System.out.print("Enter array elements:");int value = sc.nextInt();System.out.print("Enter array index:");int index = sc.nextInt();
​// 将 value 插入到数组的 index 位置insertValue(arr, index, value);
​// 打印插入后的数组System.out.println("增加元素后的数组为: ");for (int num : arr) {System.out.print(num + " ");}}
​/*往数组的指定位置添加元素@param: arr => 待插入元素的数组@param: index => 待插入元素的数组下标@param: value => 待插入数组的值*/public static void insertValue(int[] arr, int index, int value) {for (int i = arr.length - 1; i > index; i--) {arr[i] = arr[i - 1];}arr[index] = value;}
}

0x05:数组的应用 — 数组删除问题

0x0501:数组删除 — 删除指定位置上的元素

笔者直接上示例代码了,即根据用户传入的下标,删除指定位置上的元素:

import java.util.Scanner;public class TestVar {public static void main(String[] args) {int[] arr = new int[]{1, 2, 3, 4, 5};// 获取用户想要删除的元素下标Scanner sc = new Scanner(System.in);System.out.print("待删除的元素下标:");int index = sc.nextInt();// 打印删除前的数组值System.out.println("删除前的数组内容: ");for (int num : arr) {System.out.print(num + " ");}// 删除指定位置的元素deleteIndex(arr, index);// 打印删除后的数组值System.out.println("\n 删除后的数组内容: ");for (int num : arr) {System.out.print(num + " ");}}/*根据用户传入的下标位置,删除数组中指定位置上的值@param arr => 待删除的数组对象@param index => 待删除的元素位置*/public static void deleteIndex(int[] arr, int index) {for (int i = index; i < arr.length - 1; i++) {arr[i] = arr[i + 1];}arr[arr.length - 1] = 0; // 给末尾值赋 0 代表被删除}
}

0x0502:数组删除 — 删除数组中的指定元素

除了根据下标去删除数组中的内容外,我们还可以根据值进行删除:

import java.util.Scanner;public class TestVar {public static void main(String[] args) {int[] arr = new int[]{1, 2, 3, 4, 5};// 获取用户想要删除的元素下标Scanner sc = new Scanner(System.in);System.out.print("待删除的元素的内容:");int value = sc.nextInt();// 打印删除前的数组值System.out.println("删除前的数组内容: ");for (int num : arr) {System.out.print(num + " ");}// 删除数组中的指定元素deleteValue(arr, value);// 打印删除后的数组值System.out.println("\n 删除后的数组内容: ");for (int num : arr) {System.out.print(num + " ");}}/*根据用户传入的元素的值,从数组中删除指定的元素@param arr => 待删除的数组对象@param value => 待删除的元素的值*/public static void deleteValue(int[] arr, int value) {// 第一步: 从数组中查找到要删除的值的位置int index = -1;for (int i = 0; i < arr.length; i++) {if (arr[i] == value) {index = i;break;}}// 第二步: 判断数组中是否有待删除的值if (index == -1) {System.out.println("抱歉,数组红没有待删除的值 !");return;}// 第三步: 根据获得的位置,从数组中删除对应的值for (int i = index; i < arr.length - 1; i++) {arr[i] = arr[i + 1];}arr[arr.length - 1] = 0; // 给末尾值赋 0 代表被删除}
}

http://www.xdnf.cn/news/91945.html

相关文章:

  • 逻辑回归:使用 S 型函数进行概率预测
  • VMwaer虚拟机复制粘贴、ROS系统安装
  • 武装Burp Suite工具:HaE 分析辅助类_插件.【高亮标记和信息提取利器】
  • C++算法(13):如何高效读取并存储未知数量的空格分隔数字
  • 资本怪兽贝莱德投资数据分析报告-独家
  • 具有相同数量的置位(1位)的下一个更大数字
  • Qt 下载的地址集合
  • 反素数c++
  • 语音合成(TTS)从零搭建一个完整的TTS系统-第二节-中文转拼音
  • 深入解读ConcurrentHashMap特性以及源码
  • 01.Python代码Pandas是什么?pandas的简介
  • EdgeGPT - 新版Bing聊天功能逆向工程
  • pip install pymysql报错
  • Python SQL 工具包:SQLAlchemy介绍
  • oracle将表字段逗号分隔的值进行拆分,并替换值
  • Spark–steaming
  • 【LLM+Code】Claude Code Agent 0.2.9 版本最细致解读
  • Cursor Free VIP 重置进程错误,轻松恢复使用!
  • Element Plus消息通知体系深度解析:从基础到企业级实践
  • SwiftInfer —— 大模型无限流式输入推理打破多轮对话长度限制
  • 序列决策问题(Sequential Decision-Making Problem)
  • 测试开发 - Java 自动化测试核心函数详解
  • 【云馨AI-大模型】Dify 1.2.0:极速集成 SearXNG,畅享智能联网搜索新境界,一键脚本轻松部署SearXNG
  • LeetCode算法题(Go语言实现)_55
  • 麒麟系统使用-系统设置
  • 详解BUG(又名:BUG的生命周期)
  • 从0到1构建企业级消息系统服务体系(终):当消息系统学会「读心术」揭秘情感计算如何让触达转化率飙升 200%
  • Unity 导出Excel表格
  • 可变参数模板 和 折叠表达式 (C++)
  • 人工智能-模型评价与优化(过拟合与欠拟合,数据分离与混淆矩阵,模型优化,实战)