一、定义数组

/**
* 一维数组定义
*
* 为数组插入元素
*/
public void case1() {
// 声明
int[] arr1; // 声明+初始化
int[] arr2 = new int[3];
// 为数组赋值
arr2[0] = 1;
arr2[1] = 2;
arr2[2] = 3; // 声明+静态初始化,arr3和arr4一样
int[] arr3 = new int[]{1, 2, 3, 4, 5};
int[] arr4 = {1, 2, 3, 4, 5};
}

二、数组的遍历

/**
* 一维数组的访问&遍历
*/
public void case2() {
int[] arr = new int[]{1, 2, 3, 4, 5}; // 普通for循环
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
} // foreach, 增强for循环
for (int num : arr) {
System.out.println(num);
} // 第三种方式,jdk1.8支持该种方式
Arrays.stream(arr).forEach(System.out::println);
}

三、二维数组

/**
* 二维数组的定义,初始化,访问,遍历
*/
public void case3() { // 声明
int[][] arr1; // 声明+初始化
int[][] arr2 = new int[3][2];
arr2[0][0] = 1;
arr2[0][1] = 1; // 声明+静态初始化,3*3
int[][] arr3 = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
} /**
* 二维数组的遍历
*/
public void case4() { int[][] arr = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
// 第一种方式
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr[i].length; j++) {
System.out.println(arr[i][j]);
}
} // 第二种方式
for (int[] ints : arr) {
for (int i : ints) {
System.out.println(i);
}
}
}

四、总结

定义

  • 多个相同数据类型的数据按着顺序排列在一起组成的结构

属性

  • 名称: 存储数组在内存中的地址
  • 索引: 每个元素在数组中都有唯一的位置用于定位元素
  • 元素: 数组中的每一个数据,即为元素
  • 长度: 即数组中元素的个数

特点

  • 元素有序排列
  • 内存中空间连续
  • 属于引用数据类型

注意

  • 长度一旦指定即不可修改

五、练习

1、定义一个整型数组,找最大的元素

/**
* 数组练习:定义一个整型数组,找最大的元素
*/
public void case1(){
int[] arr = new int[10];
for (int i=0;i<10;i++){
arr[i] = i;
}
System.out.println(Arrays.toString(arr));
int max = arr[0];
for (int j=0;j<arr.length;j++){
if (arr[j] > max){
max = arr[j];
}
}
System.out.println(max);
}

2、定义一个二维数组,求所有元素的和

/**
* 数组练习:定义一个二维数组,求所有元素的加和
*/
public void case2(){
// 声明和初始化一个二维数组
int[][] arr = new int[5][3];
// 生成一个二维数组
for (int i=0;i<5;i++){
for (int j=0;j<3;j++){
arr[i][j] = i + j;
System.out.print(arr[i][j]+" ");
}
}
// 循环二维数组的每个元素然后相加
int sum = 0;
for (int i=0;i<arr.length;i++){
for (int j=0;j<arr[i].length;j++){
sum += arr[i][j];
}
}
// 换行
System.out.println();
System.out.println(sum);
}

3、往数组指定位置插入/删除一个元素

/**
* 往数组指定位置插入一个元素
*/
int[] insertarray(int[] arr, int index, int value){ int[] newArr = new int[arr.length + 1];
for (int i = 0; i < arr.length; i++) {
newArr[i] = arr[i];
}
for (int i = newArr.length - 1; i > index; i--) {
newArr[i] = newArr[i - 1];
}
newArr[index] = value;
arr = newArr; return arr;
} /**
* 删除数组中指定位置的元素
*/
int[] deletearray(int[] arr, int index){ int[] newArr = new int[arr.length - 1];
for (int i = 0; i <= arr.length - 1; i++){
if (i < index){
newArr[i] = arr[i];
}
else if (i > index){
newArr[i-1] = arr[i];
}
}
return newArr;
}

最新文章

  1. MYSQL 5.0 USING BTREE 错误
  2. ehcache memcache redis 三大缓存
  3. 跨列设置column-span
  4. Android Context上下文解析
  5. let it be
  6. java中同步嵌套引起的死锁事例代码
  7. 通过PHP扩展phpredis操作redis
  8. 关于iOS APP中网络层的设计
  9. XML解析(转)
  10. Linux下安装Android的adb驱动-解决不能识别的问题
  11. PowerShell 中使用json对象的性能比较
  12. Yii的场景
  13. CountDownLatch和CyclicBarrier区别及用法的demo
  14. 设计管理员表;webservice用于网络安全的高端内提供服务的
  15. HTML状态码大全(301,404,500等)
  16. msp430系统时钟
  17. 飞跃式发展的后现代 Python 世界
  18. Djangoorm的多表建立与queryset对象的合并
  19. .Net分布式锁
  20. ASP.NET Core Identity 实战(2)——注册、登录、Claim

热门文章

  1. linux ftp 添加用户及权限管理
  2. 浙大数据结构课后习题 练习一 7-1 Maximum Subsequence Sum (25 分)
  3. 如何自己搭建DNS服务器
  4. kotlin面向对象之抽象类、继承、多态
  5. 【奇淫技巧】Lyndon 分治
  6. 1.Go-copy函数、sort排序、双向链表、list操作和双向循环链表
  7. 多线程-生产者消费者(lock同步)
  8. 利用pipework为docker容器设置固定IP
  9. ie浏览器css兼容样式实例
  10. Lambda学习总结(二)--Stream流