2019-11-14 · 数组中涉及到的常见算法(上)

这一章主要学习数组中常见的算法
并且解决一下题目(杨辉三角已解决):

2019-11-14 · 数组中涉及到的常见算法(上)_第1张图片
常见算法



2019-11-14 · 数组中涉及到的常见算法(上)_第2张图片
练习题5
解:
/*
 *  定义一个int型的一维数组,包含10个元素,分别赋值
 *  然后求出所有元素的最大值,最小值,和值,平均值,并且输出出来。
 *  要求:所有随机数都是两位数。[10,99]
 *  公式:(99-10+1)+10
 */
public class Test1 {
    public static void main(String[] args) {
        //定义一个int型的一维数组
        int[] arr = new int[10];
        
        //赋值
        for(int i=0; i arr[j]) {
                min = arr[j];
            }
        }
        double avg = sum/arr.length;
        
        System.out.println("这次的最大值是:" + max);
        System.out.println("这次的最小值是:" + min);
        System.out.println("这次的平均值是:" + avg);
        System.out.println("这次的和值是:" + sum);
    }
}



2019-11-14 · 数组中涉及到的常见算法(上)_第3张图片
练习题6
解:
/*
 * 思考:  两者应该是赋值关系,
 *      第四步中的操作只是把array1的地址值赋给array2,就相当于给array1做一个快捷键,
 *      所以修改array2也会让array1改变。
 */
public class ArrayTest {
    public static void main(String[] args) {
        //在main()方法中声明array1和array2两个变量,他们是int[]类型的数组。
        int[] array1, array2;
        
        //使用大括号{},把array1初始化为8个素数:2,3,5,7,11,13,17,19
        array1 = new int[]{2,3,5,7,11,13,17,19};
        
        //显示array1的内容
        for(int i=0; i
2019-11-14 · 数组中涉及到的常见算法(上)_第4张图片
内存图解


扩展(实现array2对array1的复制)解:

数组的复制,array2首先要在堆空间中new出来一个内存,然后使用for循环,让array1的元素赋值给array2。

/*
 * 思考:  两者应该是赋值关系,
 *      第四步中的操作只是把array1的地址值赋给array2,
 *      所以修改array2也会让array1改变。
 */
public class ArrayTest {
    public static void main(String[] args) {
        //在main()方法中声明array1和array2两个变量,他们是int[]类型的数组。
        int[] array1, array2;
        
        //使用大括号{},把array1初始化为8个素数:2,3,5,7,11,13,17,19
        array1 = new int[]{2,3,5,7,11,13,17,19};
        
        //显示array1的内容
        System.out.print("array1的元素有:");
        for(int i=0; i
2019-11-14 · 数组中涉及到的常见算法(上)_第5张图片
内存图解

你可能感兴趣的:(2019-11-14 · 数组中涉及到的常见算法(上))