【数组基础知识】

二维数组

我的理解是,如果内层有值,外层打印就是地址值。如果内层没值,外层打印就是null。

int[][]a = new int [3][];

这样打印a[0]的时候是null。

打印a[0][0]会报错。

int[][]a = new int [3][1];

这样打印a[0]的时候是地址值。

打印a[0][0]是打印内层元素,这里没有赋值所以打印的是默认值0。

二维数组的length

int[][]a = new int [3][1];

a.length 就是3。是外层元素有几个集合就多少。还可以点开里后再.length

遍历二维数组两种方式:

复制代码
        for (int[] ints : d) {
            for (int anInt : ints) {
                System.out.println(anInt);
            }
        }

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

两个数组的赋值(要和复制区分开) :

复制代码
int[] a = new int[]{1,2};
int[] b = a;

注意,这里是直接把 a 的地址值 给了b,他们俩名字都在栈里,但是指向的是堆里同一个数组。如果b的数值变化了,那么a也会变化

数组的反转

复制代码
        int[] a = new int[]{1,2,3,4};
        int[] b = new int[a.length];
        //拷贝一份
        for (int i = 0; i < a.length; i++) {
            for (int j = 0; j < b.length; j++) {
                if(i == j){
                    b[j] = a[i];
                }
            }
        }
        for (int i = 0; i < a.length; i++) {
            for (int j = b.length-1; j >= 0; j--) {
                if( i + j == a.length-1){
                    a[i] = b[j];
                    break;
                }
            }
        }

        Arrays.stream(a).forEach(System.out::println);

或者。。直接在 第一次for循环a数组的时候,直接给b 赋值。这个有点酷

比如,int[] a = {1,2,3,4}

想得到 int[]b = {4,3,2,1}

其实就是 a[0],要b[4-1-0]这个位置来承接这个值。

公式:a的索引值对应的数,用 b的 length - 1 然后 再 减 a 索引值 的索引值 去接这个值。这样一次for循环就搞定了

复制代码
        int[] a = new int[]{1,2,3,4,5};
        int[] b = new int[a.length];
        //for循环的同时 直接赋值
        for (int i = 0; i < a.length; i++) {
            b[a.length -1 - i] = a[i];
        }
        Arrays.stream(b).forEach(System.out::println);

判断数组是否是对称数组

复制代码
        int[] a = new int[]{1,2,3,2,4};
        for (int i = 0; i < a.length; i++) {
            if(a[a.length -1 - i] != a[i]){
                System.out.println("不是对称数组");
                break;
            }
        }

数组的扩容和缩容

扩容必须要new 一个新的数组,因为数组长度一旦固定,不可变更。(因为Java 中的数组在创建时会分配一块连续的内存空间来存储元素。)

缩容

删除指定某个索引值的数据。

方式一:不新建数组,只是把后面的数字去覆盖前面的数字,然后最后那个位置填个0。思路清奇

相关推荐
Old Uncle Tom3 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆3 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移3 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业3 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
智者知已应修善业6 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
.5486 小时前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove7 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊7 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
code_pgf8 小时前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源
嘻嘻哈哈樱桃8 小时前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划