栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

java数组

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

java数组

数组

数组是相同类型的数据的集合

数组的声明与创建

int[] nums = new int[10];
int[] nums;  nums = new int[10];(分开写)

内存分析

初始化

//静态初始化:创建+初值
int[] a = {1,2,3,4,5,6,7,8};

//动态初始化
int[] b = new int[10];
b[0] = 10;

System.out.println(b[0]);
System.out.println(b[1]);  //默认为0

数组的四个基本特点

其长度是确定的。数组一旦被创建,它的大小是不可以改变的其元素必须是相同类型,不允许出现混合类型数组中的元素可以是任何数据元素,包括基本类型和应用类型数组本身就是对象,Java中对象是在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身是在堆中的

下标的合法区间:[0, length-1]

ArrayIndexOutOfBoundException:数组下标越界异常

数组的使用

普通的for循环

For-Each循环

//打印数组元素
public static void main(String[] args) {
    int[] arrays = {1, 2, 3, 4, 5};
    for (int x : arrays) {
            System.out.println(x);
    }        
}

数组作方法入参

//打印数组元素
public static void printArray(int[] arrays){
    for (int i = 0; i < arrays.length; i++) {
        System.out.print(arrays[i]+" ");
    }
}

数组作返回值

//反转数组
public static int[] reverse(int[] arrays){
    int[] result = new int[arrays.length];
    for (int i = 0,j = arrays.length-1; i < arrays.length; i++,j--) {
        result[j] = arrays[i];
    }
    return result;
}

多维数组

package array;

public class ArrayDemo05 {
    public static void main(String[] args) {
        //四行二列
        
        int[][] array = {{1,2},{2,3},{3,4},{4,5}};  //定义二维数组
        printArray(array[0]);
        System.out.println();
        System.out.println("===================");

        System.out.println(array[0][0]);
        System.out.println(array[0][1]);
        System.out.println("===================");

        for (int i = 0; i < array.length; i++) {
            for (int j = 0; j < array[i].length; j++) {
                System.out.println(array[i][j]);
            }
        }

    }
    //打印数组元素
    public static void printArray(int[] arrays){
        for (int i = 0; i < arrays.length; i++) {
            System.out.print(arrays[i]+" ");
        }
    }
}

冒泡排序

package array;

import java.util.Arrays;

public class ArrayDemo07 {
    public static void main(String[] args) {
        int[] a = {5,2,3,4,9000,312,99,21,3,23};
        int[] sort = sort(a);
        System.out.println(Arrays.toString(sort));

    }
    //冒泡排序(自己定义一个方法)
    public static int[] sort(int[] array){
        //临时变量
        int temp = 0;
        for (int i = 0; i < array.length-1; i++) {  //外层循环,总共要比较array.length-1轮
            boolean flag = false;  //通过flag标识符来减少没有意义的比较
            for (int j = array.length-1; j > 0 ; j--) {  //内层循环,比较两个数,如果后一个数比前一个数小,则交换位置
                if (array[j]   

稀疏数组

当一个数组中大部分元素为0,或者为同一值的数组时,可以用稀疏数组来保存该数组

稀疏数组的处理方式是:

记录数组一共有几行几列,有多少个有效值把具有不同值的元素的行列及值记录在一个小规模的数组中,从而缩小程序的规模

package array;

public class ArrayDemo08 {
    public static void main(String[] args) {
        //1.创建一个二维数组11*11    0:没有棋子  1:黑棋  2:白棋
        int[][] array1 = new int[11][11];
        array1[1][2] = 1;
        array1[2][3] = 2;

        //输出原始的数组
        System.out.println("输出原始的数组:");

        for (int[] ints: array1){
            for (int anInt: ints){
                System.out.print(anInt+"t");
            }
            System.out.println();
        }

        //二维数组稀疏存储
        //获取有效值的个数
        int sum = 0;
        for (int i = 0; i < 11; i++) {
            for (int j = 0; j < 11; j++) {
                if (array1[i][j]!=0){
                    sum++;
                }
            }
        }
        System.out.println("有效值个数:"+sum);

        //2.创建一个稀疏数组
        int [][] array2 = new int[sum+1][3];

        array2[0][0] = 11;
        array2[0][1] = 11;
        array2[0][2] = sum;
        
        //遍历二维数组,将非零的值,存放在稀疏数组中
        int count=0;
        for (int i = 0; i < array1.length; i++) {
            for (int j = 0; j < array1[i].length; j++) {
                if (array1[i][j]!=0){
                    count++;
                    array2[count][0] = i;
                    array2[count][1] = j;
                    array2[count][2] = array1[i][j];
                }
            }
        }

        //输出稀疏数组
        for (int i = 0; i < array2.length; i++) {
            for (int j = 0; j < array2[i].length; j++) {
                System.out.print(array2[i][j]+"t");
            }
            System.out.println();
        }

        System.out.println("=============================");
        System.out.println("还原");
        //1.读取稀疏数组值代表的矩阵行列数,并创建新的数组
        int [][] array3 = new int[array2[0][0]][array2[0][1]];

        //2.还原其中的值
        for (int i = 1; i < array2.length; i++) {
            array3[array2[i][0]][array2[i][1]] = array2[i][2];
        }

        //3.打印
        for (int i = 0; i < array3.length; i++) {
            for (int j = 0; j < array3[i].length; j++) {
                System.out.print(array3[i][j]+"t");
            }
            System.out.println();
        }
        
    }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/755191.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号