给定数字 [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" 开头的数字都是最小的。
    • 将排序后的字符串列表拼接成最终的数字。

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

相关推荐
蓝天星空4 分钟前
spring cloud gateway 3
java·spring cloud
罗政9 分钟前
PDF书籍《手写调用链监控APM系统-Java版》第9章 插件与链路的结合:Mysql插件实现
java·mysql·pdf
从以前12 分钟前
【算法题解】Bindian 山丘信号问题(E. Bindian Signaling)
开发语言·python·算法
一根稻草君15 分钟前
利用poi写一个工具类导出逐级合并的单元格的Excel(通用)
java·excel
kirito学长-Java18 分钟前
springboot/ssm网上宠物店系统Java代码编写web宠物用品商城项目
java·spring boot·后端
木头没有瓜32 分钟前
ruoyi 请求参数类型不匹配,参数[giftId]要求类型为:‘java.lang.Long‘,但输入值为:‘orderGiftUnionList
android·java·okhttp
奋斗的老史32 分钟前
Spring Retry + Redis Watch实现高并发乐观锁
java·redis·spring
high201134 分钟前
【Java 基础】-- ArrayList 和 Linkedlist
java·开发语言
1nullptr37 分钟前
lua和C API库一些记录
开发语言·lua