PTA - 将一整个正整数的所有位重新排序,组成一个最大数(Java)(超详细)

输入一个正整数,将这个数的所有位进行重新排序,得出最大的值。

输入格式:

输入一个正整数

输出格式:

输出排序后最大的值

输入样例:

在这里给出一组输入。例如:

19837

输出样例:

在这里给出相应的输出。例如:

98731

核心思想: 

输入一个int类型数据 num。

1. 需要创建一个数组arr,将num各个位数上的数字,存入新的数组当中。怎么存入呢?先将num转换为字符串类型,利用字符串的方法求出其长度,那么这个长度就是我们想要创建的数组的长度了。

2. 将num各个位数上的数字,纷纷存入数组

3. Arrays.sort(数组名) 将字符,从小到大排序

4. 逆序输出(输出结果是一个个字符,但题目也并未要求输出类型一定是int,结果符合题意即可)

代码样例 :

import java.util.Arrays; // 导包,实现字符串排序的方法
import java.util.Scanner;

public class Main { // pta编译题 必须写 Main
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int num = sc.nextInt(); // 以int类型输入
        int arr[] = new int [(num + "").length()]; // 创建与数据位数相等的长度数组
        // [num + ""] 是将num的int类型转换为字符串类型,[.length()]是求出字符串长度,以创建相应长度的数组
        for (int i = 0; i < arr.length; i++)
        {
            arr[i] = num % 10; // 将num的个位数赋值给数组
            num /= 10; // num 整除10,原来的十位变个位,继续赋值给数组
        }
        Arrays.sort(arr);  // 对arr字符串从小到大顺序排序
        for (int i = arr.length - 1; i >= 0; i--)
            System.out.print(arr[i]); // 逆序输出,从大到小
        System.out.println(); // 最后换行
    }
}

温故而知新 

11.14

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值