Java基础篇03

1.循环嵌套

  • 循环中套循环,一般多行多列时使用

  • 执行规则:外层循环走一次,内层循环走所有次

  • 建议:嵌套层数越少越好,能用一层就不用两层,能用两层就不用三层

  • break只能跳出当前层循环

2.数组

  • 是一种数据类型(引用类型)
  • 相同数据类型元素的集合
  • 定义:
//声明整型数组arr,包含10个元素,每个元素都是int类型,默认值为0
int[] arr = new int[10];

初始化:----初始化数组中的元素(有4种方法)

int[] arr = new int[3]; //0,0,0
int[] arr = {2,5,8}; //2,5,8
int[] arr = new int[]{2,5,8}; //2,5,8
int[] arr;
//arr = {2,5,8}; //编译错误,此方式只能声明同时初始化
arr = new int[]{2,5,8}; //正确

访问:----访问的是数组中的元素

(1) 通过(数组名.length)可以获取数组的长度(元素个数)

int[] arr = new int[4];
System.out.println(arr.length); //输出arr的长度---4

(2) 通过下标/索引来访问数组中的元素,下标从0开始,最大到(数组的长度-1)

int[] arr = new int[3];
arr[0] = 100; //给第1个元素赋值为100
arr[1] = 200; //给第2个元素赋值为200
arr[2] = 300; //给第3个元素赋值为300
//运行时发生ArrayIndexOutOfBoundsException数组下标越界异常
arr[3] = 400; 
System.out.println(arr[arr.length-1]); //输出最后一个元素的值

遍历/迭代:从头到尾挨个走一遍

int[] arr = new int[10];
for(int i=0;i<arr.length;i++){ //遍历arr数组
    arr[i] = (int)(Math.random()*100); //给每个元素赋值为0到99之间的随机数
    System.out.println(arr[i]); //输出每个元素的值
}

复制:

(1)System.arraycopy(a,1,b,0,4);

//7)数组的复制:
int[] a = {10,20,30,40,50};
int[] b = new int[6]; //0,0,0,0,0,0
//a:源数组
//1:源数组的起始下标
//b:目标数组
//0:目标数组的起始下标
//4:要复制的元素个数
System.arraycopy(a,1,b,0,4); //灵活性好
for(int i=0;i<b.length;i++){
    System.out.println(b[i]);
}

(2)

int[] b = Arrays.copyOf(a,6);

a = Arrays.copyOf(a,a.length+1); //数组的扩容

//常规复制
int[] a = {10,20,30,40,50};
//a:源数组
//b:目标数组
//6:目标数组的长度(元素个数)
//---若目标数组长度>源数组长度,则末尾补默认值
//---若目标数组长度<源数组长度,则将末尾的截掉
int[] b = Arrays.copyOf(a,6); //灵活性差
for(int i=0;i<b.length;i++){
    System.out.println(b[i]);
}

//数组的扩容
int[] a = {10,20,30,40,50};
//数组扩容(创建了一个更大的新的数组,并将源数组数据复制进去了)
a = Arrays.copyOf(a,a.length+1);
for(int i=0;i<a.length;i++){
    System.out.println(a[i]);
}

综合案例:求数组元素最大值并放到最后一个元素的下一个位置

package day06;
import java.util.Arrays;
//求数组元素的最大值,并将最大值放在数组最后一个元素的下一个位置
public class MaxOfArray {
    public static void main(String[] args) {
        int[] arr = new int[10];
        for(int i=0;i<arr.length;i++){
            arr[i] = (int)(Math.random()*100);
            System.out.println(arr[i]);
        }

        int max = arr[0]; //假设第1个元素为最大值
        for(int i=1;i<arr.length;i++){ //遍历剩余元素
            if(arr[i]>max){   //若剩余元素大于max
                max = arr[i]; //则修改max为较大的
            }
        }
        System.out.println("最大值为:"+max);

        arr = Arrays.copyOf(arr,arr.length+1); //扩容
        arr[arr.length-1] = max; //将max赋值给arr的最后一个元素
        for(int i=0;i<arr.length;i++){
            System.out.println(arr[i]);
        }
    }
}

补充:

(1)\t:水平制表位,固定占8位(2)ArrayInde
xOutOfBoundsException数组下标越界异常排序:Arrays.sort(arr); //升序排列

3.方法:函数

  • 封装一段特定的业务逻辑功能
  • 尽可能独立,一个方法只干一件事
  • 方法可以被反复多次调用
  • 减少代码重复,有利于代码维护

4.方法的定义:五要素

修饰词     返回值类型    方法名(参数列表) {

方法体-----具体业务逻辑功能实现

}

5.方法的调用:

  • 无返回值:方法名(有参传参);
  • 有返回值:数据类型 变量 = 方法名(有参传参);

return:

return值 :1) 结束方法的执行        2) 返回结果给调用方-----用在有返回值的方法中

return  : 1) 结束方法的执行-----------用在无返回值的方法中

补充:

1.形参:形式参数(定义方法时的参数)

  实参:实际参数(调用方法时的参数)`

2. 方法的嵌套调用:在方法中再调用方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值