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

《LeetCode之每日一题》:253.将一维数组转变成二维数组

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

《LeetCode之每日一题》:253.将一维数组转变成二维数组

将一维数组转变成二维数组
  • 有关题目
    • 题解

题目链接: 将一维数组转变成二维数组

有关题目
给你一个下标从 0 开始的一维整数数组 original 和两个整数 m 和  n 。
你需要使用 original 中 所有 元素创建一个 m 行 n 列的二维数组。

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

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

示例 2:

输入:original = [1,2,3], m = 1, n = 3
输出:[[1,2,3]]
解释:
构造出的二维数组应该包含 1 行 3 列。
将 original 中所有三个元素放入第一行中,构成要求的二维数组。
示例 3:

输入:original = [1,2], m = 1, n = 1
输出:[]
解释:
original 中有 2 个元素。
无法将 2 个元素放入到一个 1x1 的二维数组中,所以返回一个空的二维数组。
示例 4:

输入:original = [3], m = 1, n = 2
输出:[]
解释:
original 中只有 1 个元素。
无法将 1 个元素放满一个 1x2 的二维数组,所以返回一个空的二维数组。
提示:

1 <= original.length <= 5 * 10^4
1 <= original[i] <= 10^5
1 <= m, n <= 4 * 10^4
题解

法一:模拟
参考官方题解
C++

class Solution {
public:
    vector> construct2DArray(vector& original, int m, int n) {
        vector> ans;
        int sz = original.size();
        if (sz != m * n)
            return ans;
        
        for (auto it = original.begin(); it != original.end(); it += n)
        {
            ans.emplace_back(it, it + n);//添加新元素到容器尾
        }

        return ans;
    }
};

C

int** construct2DArray(int* original, int originalSize, int m, int n, int* returnSize, int** returnColumnSizes){
    if (originalSize != m * n)
    {
        *returnSize = 0;
        return NULL;
    }

    int ** ans = (int **)malloc(sizeof(int*) * m);
    *returnColumnSizes = (int *)malloc(sizeof(int) * m);//存放m行中每一行对应的元素长度;

    //初始化ans的空间
    for (int i = 0; i < m; i++)
    {
        ans[i] = (int*)malloc(sizeof(int) * n);//初始化每一行存放的元素的空间
        (*returnColumnSizes)[i] = n;
    }

    //拷贝每一行的元素
    for (int i = 0; i < originalSize; i += n)
    {
        memcpy(ans[i / n], original + i, sizeof(int) * n);
    }

    *returnSize = m;
    return ans;
}

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

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

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