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

LeetCode2022. 将一维数组转变成二维数组题解(easy)

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

LeetCode2022. 将一维数组转变成二维数组题解(easy)

2022. 将一维数组转变成二维数组
    • 题目内容
    • 题解
      • 复杂度
    • c++中auto什么意思

C++ vector 容器浅析
C++ STL vector添加元素(push_back()和emplace_back())详解

题目内容

2022. 将一维数组转变成二维数组
给你一个下标从 0 开始的一维整数数组 original 和两个整数 m 和 n 。你需要使用 original 中 所有 元素创建一个 m 行 n 列的二维数组。

original 中下标从 0 到 n - 1 (都 包含 )的元素构成二维数组的第一行,下标从 n 到 2 * n - 1 (都 包含 )的元素构成二维数组的第二行,依此类推。

请你根据上述过程返回一个 m x n 的二维数组。如果无法构成这样的二维数组,请你返回一个空的二维数组。

题解

设 original 的长度为 k,根据题意,如果 k = mn 则无法构成二维数组,此时返回空数组。否则我们可以遍历 original,每 n 个元素创建一个一维数组,放入二维数组中。

class Solution {
public:
    vector> construct2DArray(vector &original, int m, int n) {
        vector> ans;
        if (original.size() != m * n) {
            return ans;
        }
        for (auto it = original.begin(); it != original.end(); it += n) {
            ans.emplace_back(it, it + n);
        }
        return ans;
    }
};

作者:LeetCode-Solution
链接:https://leetcode-cn.com/problems/convert-1d-array-into-2d-array/solution/jiang-yi-wei-shu-zu-zhuan-bian-cheng-er-zt47o/
来源:力扣(LeetCode)
复杂度

时间复杂度:O(mn)O(mn) 或 O(m)O(m)(取决于语言实现)。
空间复杂度:O(1)O(1)。不考虑返回值的空间占用。

c++中auto什么意思

C语言auto被解释为一个自动存储变量的关键字,也就是申明一块临时的变量内存。例如:表示a为一个自动存储的临时变量。
C语言中提供了存储说明符auto、register、extern、static说明的四种存储类别。
四种存储类别说明符有两种存储期:自动存储期和静态存储期。
其中auto和register对应自动存储期。具有自动存储期的变量在进入声明该变量的程序块时被建立,它在该程序块活动时存在,退出该程序块时撤销。在函数内部定义的变量成为局部变量。在某些C语言教材中,局部变量称为自动变量,这就与使用可选关键字auto定义局部变量这一作法保持一致。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/690906.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

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

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