【算法一则】【贪心】数组中的数可以拼装成的最大数

题目

给定一组非负整数 nums,重新排列每个数的顺序(每个数不可拆分)使之组成一个最大的整数。

注意:输出结果可能非常大,所以你需要返回一个字符串而不是整数。

示例 1:

复制代码
输入:nums = [10,2]
输出:"210"
示例 2:

输入:nums = [3,30,34,5,9]
输出:"9534330"
提示:

1 <= nums.length <= 100
0 <= nums[i] <= 109

题解

java 复制代码
import java.util.List;

//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public String largestNumber(int[] nums) {
        // 创建一个List集合来存储数组中的数字
        List<String> collect = new ArrayList<>();
        for (int num : nums) {
            // 将数组中的每个数字转换为字符串并添加到集合中
            collect.add(String.valueOf(num));
        }
        // 调用pickMaximumNumber方法找到能够组成的最大数字
        String pickMaximumNumber = pickMaximumNumber(collect);
        // 如果最大数字的第一个字符是0,则返回"0",否则返回最大数字
        if (pickMaximumNumber.charAt(0) == '0') {
            return "0";
        }
        return pickMaximumNumber;
    }

    // 找到能够组成的最大数字的方法
    public String pickMaximumNumber(List<String> list) {
        // 使用自定义的比较器对集合中的数字进行排序
        list.sort((o1, o2) -> {
            String s1 = o1 + o2;
            String s2 = o2 + o1;
            // 将两个数字组合后进行比较,返回比较结果
            return s2.compareTo(s1);
        });
        // 将排序后的数字拼接成一个字符串并返回
        return String.join("", list);
    }
}

题目要求找到给定整数数组中能够组成的最大数字。我们可以通过将数组中的数字转换为字符串,并进行排序来实现。

  1. 首先,我们创建一个List集合来存储数组中的数字。然后,使用一个循环遍历整数数组,将每个数字转换为字符串,并将其添加到集合中。

  2. 接下来,我们调用一个自定义的方法pickMaximumNumber来找到能够组成的最大数字。这个方法接受一个List参数,表示存储数字的集合。

  3. pickMaximumNumber方法中,我们使用集合的sort方法,并传入一个自定义的比较器。比较器的逻辑是将两个数字组合起来,然后比较它们的大小。具体而言,我们将两个数字分别拼接成两个字符串s1s2,然后比较s2s1的大小。这样做的目的是为了确保组合后的数字能够得到最大的排序结果。

  4. 排序完成后,我们将排序后的数字通过String.join方法拼接成一个字符串,并将其作为方法的返回值。

  5. 回到largestNumber方法,在调用pickMaximumNumber方法后,我们检查最大数字的第一个字符是否为0。如果是0,说明最大数字是以0开头的,那么无论后面的数字如何,它们都不会改变最大数字的值,因此我们直接返回字符串"0"。如果最大数字的第一个字符不是0,我们就返回最大数字。

这样,我们就得到了给定整数数组中能够组成的最大数字。

总结起来,这段代码的思路是将整数数组转换为字符串,并使用自定义的比较器对字符串进行排序,从而找到能够组成的最大数字。最后,根据题目要求进行处理并返回结果。

相关推荐
崎岖Qiu15 分钟前
leetcode100.相同的树(递归练习题)
算法·leetcode·二叉树·力扣·递归
No0d1es7 小时前
电子学会青少年软件编程(C/C++)5级等级考试真题试卷(2024年6月)
c语言·c++·算法·青少年编程·电子学会·五级
大阳1239 小时前
线程(基本概念和相关命令)
开发语言·数据结构·经验分享·算法·线程·学习经验
weixin_3077791310 小时前
VS Code配置MinGW64编译GNU 科学库 (GSL)
开发语言·c++·vscode·算法
学行库小秘11 小时前
ANN神经网络回归预测模型
人工智能·python·深度学习·神经网络·算法·机器学习·回归
没落之殇11 小时前
基于C语言实现的HRV分析方法 —— 与Kubios和MATLAB对比
算法
秋难降11 小时前
线段树的深度解析(最长递增子序列类解题步骤)
数据结构·python·算法
楚韵天工11 小时前
基于GIS的无人机模拟飞行控制系统设计与实现
深度学习·算法·深度优先·无人机·广度优先·迭代加深·图搜索算法
你也向往长安城吗12 小时前
推荐一个三维导航库:three-pathfinding-3d
javascript·算法
百度智能云13 小时前
VectorDB+FastGPT一站式构建:智能知识库与企业级对话系统实战
算法