LeetCode | 2022.将一维数组转变为二维数组



这道题思路比较简单,比较容易想到的是先判断m和n构成的二维数组在形式上是否可以由原来的数组转变而成,若不可以返回空数组,若可以直接用一个二重循环遍历一遍即可,时间复杂度 O ( n 2 ) O(n^2) O(n2)

python 复制代码
class Solution(object):
    def construct2DArray(self, original, m, n):
        """
        :type original: List[int]
        :type m: int
        :type n: int
        :rtype: List[List[int]]
        """
        ans = [[0] * n for _ in range(m)]

        if m * n != len(original):
            return []
        elif m == 1:
            return [original]
        else:
            count = 0
            for i in range(m):
                for j in range(n):
                    ans[i][j] = original[count]
                    count += 1
        return ans

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

python 复制代码
class Solution:
    def construct2DArray(self, original: List[int], m: int, n: int) -> List[List[int]]:
        return [original[i: i + n] for i in range(0, len(original), n)] if len(original) == m * n else []
相关推荐
有意义23 分钟前
为什么说数组是 JavaScript 开发者必须精通的数据结构?
前端·数据结构·算法
努力努力再努力wz24 分钟前
【Linux进阶系列】:线程(下)
linux·运维·服务器·c语言·数据结构·c++·算法
rit843249936 分钟前
瑞利信道下PSK水声通信系统均衡技术
算法
ValhallaCoder1 小时前
Day33-动态规划
数据结构·python·算法·动态规划
不穿格子的程序员1 小时前
从零开始刷算法-二分-搜索插入位置
算法·二分查找
zhugby2 小时前
受限长度路径搜索算法
经验分享·算法·启发式算法·哈密顿问题·路径搜索算法
芋头莎莎2 小时前
STM32利用AES加密数据、解密数据
数据结构·stm32·算法
caron42 小时前
c++ -- 循环依赖解决方案
java·c++·算法
Kt&Rs2 小时前
11.11 LeetCode 题目汇总与解题思路
算法·leetcode·哈希算法
py有趣2 小时前
LeetCode算法学习之有效的字母异位词
学习·算法·leetcode