黑马程序员--Java编程之数组篇
来源:互联网 发布:影视行业 知乎 编辑:程序博客网 时间:2024/06/04 18:33
——Java培训、Android培训、iOS培训、.Net培训、期待与您交流! ——-
1.数组的概念
数组是存储同一种数据类型多个元素的集合。也可以看成是一个容器。
数组既可以存储基本数据类型,也可以存储引用数据类型。
数组长度固定,可以存储重复元素
2.数组的定义格式
格式1:数据类型[] 数组名;
格式2:数据类型 数组名[];
3.数组的初始化
3.1 数组初始化概述
Java中的数组必须先初始化,然后才能使用。
所谓初始化:就是为数组中的数组元素分配内存空间,并为每个数组元素赋值。
3.2 数组的初始化方式
动态初始化:初始化时只指定数组长度,由系统为数组分配初始值。
列如:int[] arr = new int[5];
定义了一个int类型的名为arr的数组,数组的长度为5,因为元素类型是int类型,所以系统会给每一个元素的值默认初始化为0。
静态初始化:初始化时指定每个数组元素的初始值,由系统决定数组长度。
例如:int[] arr = {3,5,7,9,13};
定义了一个int类型的名为arr的数组,数组中的元素已给出:3,5,7,9,13,所以数组arr的长度为5
4.数组操作中常见的两个异常
4.1 数组索引越界
ArrayIndexOutOfBoundsException
访问到了数组中的不存在的索引时发生
4.2 空指针异常
NullPointerException
数组引用没有指向实体,却在操作实体中的元素时。
5.数组常见操作
5.1 数组遍历
数组的遍历就是依次输出数组中的每一个元素
实现方法:for循环
举例:
public class Demo{ public static void main(String[] args){ //创建一个数组对象 int[] arr = {1,5,7,9,12,17,23,36}; //遍历数组 System.out.print("["); for(int i = 0 ; i < arr.length ; i++){ if(i == arr.length-1) System.out.println(arr[i] + "]"); else System.out.print(arr[i] + ","); } }}
5.2获取数组中元素最值
实现方法:定义一个变量用来存储最值,遍历数组,将数组中每一个元素与该变量比较,根据比较的结果来改变变量的值
public class Demo{ public static void main(String[] args){ //创建一个数组对象 int[] arr = {14,5,27,49,12,17,3,36}; //定义变量存储最值 int max = arr[0]; int min = arr[0]; //遍历数组进行比较 //获取最大值 for(int i = 0 ; i < arr.length ; i++){ if(max < arr[i]){ max = arr[i]; } } //获取最小值 for(int i = 0 ; i < arr.length ; i++){ if(min > arr[i]){ min = arr[i]; } } //在控制台显示出最大值最小值 System.out.println("最大值为:" + max + ",最小值为:" + min); }}
5.3 数组排序
5.3.1 选择排序
实现原理:
将数组中0索引的元素与其他元素一一比较,如果0索引元素的值大于与之相比较的元素,则将两者位置互换,比较完之后最小值则出现在0索引位置,再将1索引位置的元素做相同比较,以此类推,则可以实现数组的排序
代码体现:
public class Demo{ public static void main(String[] args){ //创建要排序的数组 int[] arr = {21,15,33,45,0,9,66}; //将数组进行排序 for(int i = 0 ; i < arr.length-1 ; i++){ for(int j = i + 1 ; j < arr.length ; j++){ if(arr[i] > arr[j]){ int temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; } } } //在控制台显示排好的数组 System.out.print("["); for(int i = 0 ; i < arr.length ; i++){ if(i == arr.length-1) System.out.println(arr[i] + "]"); else System.out.print(arr[i] + ","); } }}
5.3.2冒泡排序
实现原理:
将每个相邻的元素做比较,如果前一索引位置元素的值大于后一索引位置的元素,则将两者互换位置,那么第一轮比较结束最大值出现在最后一位,然后继续循环,一次类推,则可实现数组的排序
代码体现:
public class Demo{ public static void main(String[] args){ //创建要排序的数组 int[] arr = {21,15,33,45,0,9,66}; //将数组进行排序 for(int i = 0 ; i < arr.length - 1 ; i++){ for(int j = 0 ; j < arr.length - - 1 ; j++){ if(arr[j] > arr[j+1]){ int temp = arr[j]; arr[j] = arr[j+1]; arr[j+1] = temp; } } } //在控制台显示排好的数组 System.out.print("["); for(int i = 0 ; i < arr.length ; i++){ if(i == arr.length-1) System.out.println(arr[i] + "]"); else System.out.print(arr[i] + ","); } }}
- 黑马程序员--Java编程之数组篇
- 黑马程序员---Java基础篇之数组
- 黑马程序员———Java编程基础之数组
- 黑马程序员--Java编程之基础篇
- 黑马程序员--Java编程之反射篇
- 黑马程序员—基础篇之初识java数组
- 黑马程序员—【Java基础篇】之数组
- 黑马程序员--- java基础学习之数组
- 黑马程序员Java知识回顾之数组
- 黑马程序员java自学之--数组
- 黑马程序员 java基础之数组
- 黑马程序员——Java之数组
- 黑马程序员--java基础复习之数组
- 黑马程序员--Java基础语法之数组
- 黑马程序员—【Java基础篇】之网络编程
- 黑马程序员--java学习之网络编程
- 黑马程序员---java基础之网络编程
- <<黑马程序员>>java基础之网络编程
- https(ssl)连接之python实现
- WebKit之应用场景的思考
- Linux学习笔记(9)之Shell编程入门--判断语句
- linux socket编程简单例子//代码
- JAVA_SE-----基础知识总结-----多线程
- 黑马程序员--Java编程之数组篇
- 显示一个文件的某几行
- source和build分离
- Java中静态变量与静态方法的继承
- PHP常驻内存与单例模式
- 黑马程序员__Java入门知识,变量,数据类型……
- C语言编程规范
- android: OnClickListener cannot be resolved to a type
- Linux<十五>:程序管理之前台、后台