首页 > 其他分享 >12-数组

12-数组

时间:2024-06-23 16:54:56浏览次数:30  
标签:12 int System arrays 数组 new out

数组的概述

  • 相同类型数据的有序集合
  • 按照一定的先后次序排序组合而成
  • 每个数组元素可以通过一个下标来访问它们
  • 数组一旦被创建,它的大小就不可改变
  • 数组中的元素可以是任何数据类型,包括基本类型和引用类型
  • 数组变量属于引用类型,数组也可以看成是对象,数组中的每个元素相当于该对象的成员变量。数组本身就是对象,Java中的对象是在堆中。

数组的声明创建

  • 首先声明数组变量,才能使用数组
dataType[] arrayRefVar; //声明数组变量的语法
  • Java使用new操作来创建数组
dataType[] arrayRefVar = new dataType[arraySize];使用new操作符来创建数组
    //数组类型
    public static void main(String[] args) {
        /*
        dataType[] arrayRefVar; //声明数组变量的语法
         */
        int[] nums;//1.声明数组  首选方法
        //int nums[];第二种写法

        /*
        dataType[] arrayRefVar = new dataType[arraySize];使用new操作符来创建数组
         */
        nums = new int[10];//2.创建数组,可以存放10个int类型的数字

        //int[] nums2 = new int[10]; 通常合并1,2两步到一起
}
  • 数组的元素是通过索引访问的,从0开始
  • 获取数组长度
arrays.length

三种初始化

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

        //引用类型   (Man是一个类)
        Man[] mans = {new Man(),new Man()};

        //动态初始化  (包含默认初始化:未赋值的为默认值,如int类型默认为0)
        int[] b = new int[10];
        b[0] = 10;

数组的使用

数组边界

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

    public static void main(String[] args) {
        int[] arrays = {1,2,3,4,5};

        //For-each增强for循环:arrays.for+回车
        //通常用来打印一些东西
        for (int array : arrays) {
            System.out.println(array);
        }//取不到下标

        printArray(arrays);

        System.out.println();
        ArrayDemo04 arrayDemo04 = new ArrayDemo04();
        int[] reverse = arrayDemo04.reverse(arrays);
        printArray(reverse);
    }
    //方法:打印数组元素
    public static void printArray(int[] arrays){
        for (int i = 0; i < arrays.length; i++) {
            System.out.print(arrays[i] + " ");
        }
    }
    //方法:反转数组
    //数组作为入参,返回值
    public int[] reverse(int[] arrays){
        int temp;
        for (int i = 0; i < arrays.length/2; i++) {
            temp = arrays[i];
            arrays[i] = arrays[arrays.length-1-i];
            arrays[arrays.length-1-i] = temp;
        }
        return arrays;
    }

多维数组

  • 多维数组可以看成是数组的数组,比如二维数组就是一个特殊的一维数组,其每一个元素都是一个一维数组。
int[][] a = new int[2][5];
        //[4][2]
        /*
        1,2    array[0]
        2,3    array[1]
        3,4
        4,5
         */
        int[][] array = {{1,2},{2,3},{3,4},{4,5}};

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

Arrays类

  • 工具类
        int[] a={1,2,3,4,9090,31231,543,21,3,23};

        //Arrays类中的方法都是static修饰的静态方法,可以直接用类名进行调用
        //打印数组元素
        System.out.println(Arrays.toString(a));

        //排序
        Arrays.sort(a);//升序

        System.out.println(Arrays.toString(a));

        Arrays.fill(a,0);//数组填充,数组a中所有元素为0,也可以指定起止下标

        /*
        具有以下常用功能
        - 给数组赋值:通过fill方法
        - 对数组排序:通过sort方法,按升序
        - 比较数组: 通过equals方法比较数组中元素值是否相等
        - 查找数组元素: 通过binarySearch方法能对排序好的数组进行二分查找
         */

稀疏数组

  • 是一种数据结构:压缩算法
  • 当一个数组中大部分元素为0,或者为同一值的数组时,可以用稀疏数组来保存该数组

处理方式

  • 记录数组一共有几行几列,有多少不同值
  • 把具有不同值的元素和行列及值记录在一个小规模的数组中,从而压缩小程序的规模
        //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;

        //遍历二维数组,将非0值,放入稀疏数组中
        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++) {
            System.out.println(array2[i][0] + "\t" + array2[i][1] + "\t" + array2[i][2]);
        }
        /*
输出:
输出原始数组
0	0	0	0	0	0	0	0	0	0	0
0	0	1	0	0	0	0	0	0	0	0
0	0	0	2	0	0	0	0	0	0	0
0	0	0	0	0	0	0	0	0	0	0
0	0	0	0	0	0	0	0	0	0	0
0	0	0	0	0	0	0	0	0	0	0
0	0	0	0	0	0	0	0	0	0	0
0	0	0	0	0	0	0	0	0	0	0
0	0	0	0	0	0	0	0	0	0	0
0	0	0	0	0	0	0	0	0	0	0
0	0	0	0	0	0	0	0	0	0	0
有效值个数:2
11	11	2
1	2	1
2	3	2
         */

标签:12,int,System,arrays,数组,new,out
From: https://www.cnblogs.com/Mc9r4dy/p/18263605

相关文章

  • 【漏洞复现】WordPress MasterStudy LMS插件 SQL注入漏洞(CVE-2024-1512)
    0x01产品简介WordPress和WordPressplugin都是WordPress基金会的产品。WordPress是一套使用PHP语言开发的博客平台。该平台支持在PHP和MySQL的服务器上架设个人博客网站。WordPressplugin是一个应用插件。0x02漏洞概述WordPressPluginMasterStudyLMS3.2.5版本......
  • 力扣-122. 买卖股票的最佳时机 II
    1.题目题目地址(122.买卖股票的最佳时机II-力扣(LeetCode))https://leetcode.cn/problems/best-time-to-buy-and-sell-stock-ii/题目描述给你一个整数数组prices,其中 prices[i]表示某支股票第i天的价格。在每一天,你可以决定是否购买和/或出售股票。你在任何时候 最......
  • NumPy数组的分割
    NumPy数组的分割方法说明split()分割数组hsplit()沿横轴分割数组vsplit()沿纵轴分割数组1.split()np.split(arr,整数或数组,axis=n)(1)整数importnumpyasnparr=np.arange(10)res=np.split(arr,5)print("arr:")print(arr)print("res:")p......
  • LeetCode 448. 找到所有数组中消失的数字(哈希表)
    448.找到所有数组中消失的数字思路:方法一,借助额外的0(n)空间sta进行哈希classSolution{public:vector<int>findDisappearedNumbers(vector<int>&nums){intn=nums.size();vector<int>sta(n,0);for(inti=0;i<n;i++){......
  • 数组元素的数量
    在数组初始化时,我们不希望将数组大小写死,后续可能会有修改,那么对于未指定大小的数组,如何计算其元素个数?思路:已知数组名代表整个数组的物理大小,数组内单个元素代表数组的一个单元物理大小,假设数组物理空间是100,单个元素物理空间是5,那么该数组一共有20个元素。array_element_numbe......
  • 力扣-121. 买卖股票的最佳时机
    1.题目题目地址(121.买卖股票的最佳时机-力扣(LeetCode))https://leetcode.cn/problems/best-time-to-buy-and-sell-stock/题目描述给定一个数组prices,它的第 i个元素 prices[i]表示一支给定股票第i天的价格。你只能选择某一天买入这只股票,并选择在未来的某一个......
  • 力扣-1630. 等差子数组
    1.题目介绍题目地址(1630.等差子数组-力扣(LeetCode))https://leetcode.cn/problems/arithmetic-subarrays/题目描述如果一个数列由至少两个元素组成,且每两个连续元素之间的差值都相同,那么这个序列就是等差数列。更正式地,数列s是等差数列,只需要满足:对于每个有效的i,s[i......
  • Lightroom Classic 2023 for Mac(摄影后期图像编辑工具) v12.4版
    lightingClassic是Adobe公司推出的一款图像处理软件,是数字摄影后期制作的重要工具之一。与其他图像处理软件相比,LightroomClassic具有以下特点:LightroomClassic2023forMac(摄影后期图像编辑工具)软件地址高效的图像管理:LightroomClassic提供了强大的图像管理功能,可以......
  • 152. 乘积最大子数组
    152.乘积最大子数组题目链接:152.乘积最大子数组代码如下:classSolution{public:intmaxProduct(vector<int>&nums){intres=nums[0];vector<int>f(nums.size()+1,0),g(nums.size()+1,0);f[0]=nums[0],g[0]=nums[0];......
  • 小程序+spring boot流浪动物救助系统 毕业设计-附源码12783
    摘 要随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,流浪动物救助系统被用户普遍使用,为方便用户能够可以随时进行在线查看校园志愿者的数据信息管理,特开发了流浪动物救助系......