数串

本文介绍了一种通过比较和排序来构建最大整数的方法。给定一组正整数,通过特定的排序算法将它们组合成一个最大的整数。示例代码展示了如何实现这一算法,并给出了具体的运行实例。
题目描述:设有n个正整数,将他们连接成一排,组成一个最大的多位整数。如:n=3时,3个整数13,312,343,连成的最大整数为34331213。如:n=4时,4个整数7,13,4,246连接成的最大整数为7424613。
代码如下:
package practise;
import java.util.*;
public class Main {
 
 public static void main(String[] args) {
  // 数串
   System.out.println("请至少输入两个数字,用空格隔开:");
         Scanner sc=new Scanner(System.in);
         String[] s=sc.nextLine().split(" ");
         new Main().zuhe(s); 
  
 }
 private void zuhe(String[] array) {  
        String temp; 
        for(int i=0;i<array.length-1;i++){ 
            for(int j=0;j<array.length-1-i;j++){ 
                if (!compare(array[j] ,array[j+1])) {  //比较排序
                    temp=array[j]; 
                    array[j]=array[j+1]; 
                    array[j+1]=temp; 
                } 
            } 
        } 
        String sum = ""; 
        for(int i=0;i<array.length;i++){ 
             sum += array[i];  //排序的字符串相加成串
 } 
     System.out.println(sum); 
    public boolean compare(String o1, String o2) {  //利用字符串相加比较大小
    if(((o1 + o2).compareTo(o2 + o1)) > 0) { 
        return true; 
    } else { 
        return false; 
      } 
     } 
}

实例:
输入——
   2
12 123
4
7 13 4 246
输出——
12312
7424613
第二篇哦,新手小白,面临就业日常焦虑,不如踏实刷题,每日一刷每日一汇总,借鉴别人思路,欢迎学习交流参考,共同进步,提高菜鸟代码能力!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值