LeetCode - 2024 - 将一维数组变成二维数组 - Java

srcPos == source position - 源头中某个位置;

destPos == destination positon - 目标中某个位置;

length - 长度/元素个数;

System.arraycopy 的功能就是: 把 源头的数组,从 源头中某个位置开始 拷贝,拷贝到 destination 中的 某个位置。拷贝元素个数为 length / 拷贝长度为 length。


代码如下:



class Solution {

    public int[][] construct2DArray(int[] original, int m, int n) {

        if(original.length != m * n){

            return new int[0][];

        }

        int[][] array = new int[m][n];

        for(int i = 0;i < original.length;i+=n){

            System.arraycopy(original,i,array[i/n],0,n);

        }

        return array;

    }

}



在这里插入图片描述


代码细节

在这里插入图片描述


还有一种方法,就是双重循环拷贝。

===============================================================================

一个元素一个元素的拷贝

代码如下



class Solution {

    public int[][] construct2DArray(int[] original, int m, int n) {

        if(original.length != m * n){

            return new int[0][];

        }

        int[][] array = new int[m][n];

        // for(int i = 0;i < original.length;i+=n){

        //     System.arraycopy(original,i,array[i/n],0,n);

        // }

        int o = 0;// 用来记录 拷贝到 original数组中第几个元素的下标

        for(int i = 0;i < m; i++){

            for(int j = 0; j < n; j++){



# 写在最后

学习技术是一条慢长而艰苦的道路,不能靠一时激情,也不是熬几天几夜就能学好的,必须养成平时努力学习的习惯。所以:贵在坚持!

最后再分享的一些BATJ等大厂20、21年的面试题,把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。

![蚂蚁金服三面直击面试官的Redis三连,Redis面试复习大纲在手,不慌](https://img-blog.csdnimg.cn/img_convert/8103a66ac9e2c4e64948f67811821e5f.webp?x-oss-process=image/format,png)

Mybatis面试专题

![蚂蚁金服三面直击面试官的Redis三连,Redis面试复习大纲在手,不慌](https://img-blog.csdnimg.cn/img_convert/95575f904088ad15f4d7af2fc98c8af3.webp?x-oss-process=image/format,png)

MySQL面试专题

![蚂蚁金服三面直击面试官的Redis三连,Redis面试复习大纲在手,不慌](https://img-blog.csdnimg.cn/img_convert/76803367089aadfaf8de51375bdef83c.webp?x-oss-process=image/format,png)

并发编程面试专题

65)]

Mybatis面试专题

[外链图片转存中...(img-0fjqtIuQ-1719279489766)]

MySQL面试专题

[外链图片转存中...(img-SEeOmYkG-1719279489766)]

并发编程面试专题

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值