【Leetcode 每日一题】2610. 转换二维数组

问题背景

给你一个整数数组 n u m s nums nums。请你创建一个满足以下条件的二维数组:

  • 二维数组应该 包含数组 n u m s nums nums 中的元素。
  • 二维数组中的每一行都包含 不同 的整数。
  • 二维数组的行数应尽可能

返回结果数组。如果存在多种答案,则返回其中任何一种。

请注意,二维数组的每一行上可以存在不同数量的元素。

数据约束

  • 1 ≤ n u m s . l e n g t h ≤ 200 1 \le nums.length \le 200 1≤nums.length≤200
  • 1 ≤ n u m s [ i ] ≤ n u m s . l e n g t h 1 \le nums[i] \le nums.length 1≤nums[i]≤nums.length

解题过程

用哈希表统计各个数字出现的次数,最后构造答案即可。

答案的结构是嵌套的列表,有 API 的帮助可以在一个循环中完成所有操作,但是性能提升微乎其微,就不专门记录了。

具体实现

java 复制代码
class Solution {
    public List<List<Integer>> findMatrix(int[] nums) {
        List<List<Integer>> res = new ArrayList<>();
        int[] count = new int[210];
        int length = 0;
        for (int num : nums) {
            length = Math.max(length, ++count[num]);
        }
        while (length-- > 0) {
            List<Integer> list = new ArrayList<>();
            for (int i = 0; i < count.length; i++) {
                if (count[i] > 0) {
                    list.add(i);
                    count[i]--;
                }
            }
            res.add(list);
        }
        return res;
    }
}
相关推荐
desssq8 分钟前
力扣:70. 爬楼梯
算法·leetcode·职场和发展
clock的时钟39 分钟前
暑期数据结构第一天
数据结构·算法
小小小小王王王1 小时前
求猪肉价格最大值
数据结构·c++·算法
岁忧1 小时前
(LeetCode 面试经典 150 题 ) 58. 最后一个单词的长度 (字符串)
java·c++·算法·leetcode·面试·go
BIYing_Aurora2 小时前
【IPMV】图像处理与机器视觉:Lec13 Robust Estimation with RANSAC
图像处理·人工智能·算法·计算机视觉
martian6653 小时前
支持向量机(SVM)深度解析:从数学根基到工程实践
算法·机器学习·支持向量机
孟大本事要学习3 小时前
算法19天|回溯算法:理论基础、组合、组合总和Ⅲ、电话号码的字母组合
算法
SuperW3 小时前
数据结构——队列
数据结构
??tobenewyorker4 小时前
力扣打卡第二十一天 中后遍历+中前遍历 构造二叉树
数据结构·c++·算法·leetcode
让我们一起加油好吗4 小时前
【基础算法】贪心 (二) :推公式
数据结构·数学·算法·贪心算法·洛谷