给定数字 [3, 30, 34, 5, 9] 拼接成的最大数字,使用java实现

要解决这个问题,我们需要将给定的数字列表转换为字符串列表,然后根据自定义的比较规则对这些字符串进行排序,最后将排序后的字符串连接起来形成最大的数字。

以下是详细的步骤:

  1. 将每个数字转换为字符串:这允许我们使用字符串比较。
  2. 自定义排序:我们需要定义一个比较函数,该函数比较两个字符串 (a) 和 (b),通过比较 (a+b) 和 (b+a) 来确定哪个更大。如果 (a+b) 更大,则 (a) 应该排在 (b) 前面。
  3. 排序:使用自定义比较函数对所有字符串进行排序。
  4. 拼接字符串:将排序后的字符串拼接在一起,形成最终的数字。

让我们应用这些步骤到给定的例子 3, 30, 34, 5, 9

  1. 将每个数字转换为字符串:"3", "30", "34", "5", "9"

  2. 自定义排序:

    • 比较 "3" 和 "30":"3"+"30"="330","30"+"3"="303","330" > "303",所以 "3" 在 "30" 前面。
    • 比较 "3" 和 "34":"3"+"34"="334","34"+"3"="343","343" > "334",所以 "34" 在 "3" 前面。
    • 比较 "3" 和 "5":"3"+"5"="35","5"+"3"="53","53" > "35",所以 "5" 在 "3" 前面。
    • 比较 "3" 和 "9":"3"+"9"="39","9"+"3"="93","93" > "39",所以 "9" 在 "3" 前面。
    • 比较 "30" 和 "34":"30"+"34"="3034","34"+"30"="3430","3430" > "3034",所以 "34" 在 "30" 前面。
    • 比较 "30" 和 "5":"30"+"5"="305","5"+"30"="530","530" > "305",所以 "5" 在 "30" 前面。
    • 比较 "30" 和 "9":"30"+"9"="309","9"+"30"="930","930" > "309",所以 "9" 在 "30" 前面。
    • 比较 "34" 和 "5":"34"+"5"="345","5"+"34"="534","534" > "345",所以 "5" 在 "34" 前面。
    • 比较 "34" 和 "9":"34"+"9"="349","9"+"34"="934","934" > "349",所以 "9" 在 "34" 前面。
    • 比较 "5" 和 "9":"5"+"9"="59","9"+"5"="95","95" > "59",所以 "9" 在 "5" 前面。
  3. 排序后的字符串:"9", "5", "34", "30", "3"

  4. 拼接字符串:"9534330"

因此,给定数字 3, 30, 34, 5, 9 拼接成的最大数字是 9534330。

在Java中,我们可以通过实现自定义的比较器(Comparator)来解决这个问题。以下是完整的Java代码实现:

java 复制代码
import java.util.Arrays;
import java.util.Comparator;
import java.util.List;
import java.util.stream.Collectors;

public class LargestNumber {

    public static void main(String[] args) {
        List<Integer> numbers = Arrays.asList(3, 30, 34, 5, 9);
        String largestNumber = makeLargestNumber(numbers);
        System.out.println(largestNumber);
    }

    public static String makeLargestNumber(List<Integer> nums) {
        // 将整数转换为字符串,并自定义比较器
        List<String> sortedNums = nums.stream()
                .map(String::valueOf)
                .sorted((a, b) -> (b + a).compareTo(a + b))
                .collect(Collectors.toList());

        // 如果第一个字符是0,则返回"0"
        if (sortedNums.get(0).equals("0")) {
            return "0";
        }

        // 将排序后的字符串拼接成最终的数字
        return sortedNums.stream().collect(Collectors.joining());
    }
}

代码解释:

  1. 导入必要的类

    • java.util.Arrays:用于数组操作。
    • java.util.Comparator:用于自定义比较器。
    • java.util.List:用于列表操作。
    • java.util.stream.Collectors:用于流操作。
  2. 主函数

    • 定义一个整数列表 numbers
    • 调用 makeLargestNumber 方法并打印结果。
  3. makeLargestNumber 方法

    • 将整数列表转换为字符串列表。
    • 使用自定义比较器对字符串进行排序。比较器比较两个字符串 ab 时,通过比较 b + aa + b 的大小来确定顺序。
    • 如果排序后的第一个字符串是 "0",则返回 "0",因为任何以 "0" 开头的数字都是最小的。
    • 将排序后的字符串列表拼接成最终的数字。

这个实现确保了数字列表可以被正确地排序并拼接成最大的数字。

相关推荐
人活一口气3 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP4 小时前
Vibe Coding -- 完整项目案例实操
java
荣码4 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing4 小时前
Google第三方授权登录
java·后端·程序员
明月光8185 小时前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
考虑考虑14 小时前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯15 小时前
GoF设计模式——中介者模式
java·后端·spring·设计模式
青石路18 小时前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java
像我这样帅的人丶你还21 小时前
Java 后端详解(五):Redis 缓存
java·后端·全栈
plainGeekDev1 天前
GreenDAO → Room
android·java·kotlin