PTA(JAVA)——1006 换个格式输出整数 (15 分)

该篇博客介绍了一道编程题目,要求使用特定格式输出不超过3位的正整数。博主分享了Java代码实现,通过提取百位、十位和个位数字,分别用B、S和1到9的数字表示,并提供了详细的代码解析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

PTA(JAVA)——1006 换个格式输出整数 (15 分)

让我们用字母 B 来表示“百”、字母 S 表示“十”,用 12…n 来表示不为零的个位数字 n(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234,因为它有 2 个“百”、3 个“十”、以及个位的 4。

输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。

输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。

输入样例 1:
234

输出样例 1:
BBSSS1234

输入样例 2:
23

输出样例 2:
SS123

思路
根据题意,我们知道录入的是百位数。百位和十位数字的操作原理是一样的,而个位数,是用取个位的大小,按个位大小顺序输出 1-n(n<10) 举个例子:个位是5 输出:12345。

  • 提取出百位上的数字,然后以数字大小为限制,循环打印代替字母B
  • 十位与百位相同,提取出十位上的数字,然后以数字大小为限制,循环打印代替字母S
  • 提取个位数字,以个位数字大小为限制,for循环打印从 1 - n。
import java.util.Scanner;

public class Main{
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        //取出百位
        int b = n / 100;  
        //取出十位
        int s = n /10 % 10;  
        //取出个位
        int g = n % 10;  
        
	while (b > 0) {
            System.out.print("B");
            b--;
        }
        
        while (s > 0) {
            System.out.print("S");
            s--;
        }
          
        for (int i = 1; i <= g; i++) {
            System.out.print(i);
        }
    }
}

这题还是挺简单的,大家有啥好想法,也可以交流交流鸭!

### Java 实现整数倒序输出 PTA 题目解法 为了实现Java中的整数倒序输出,可以采用多种方法。下面提供一种基于控制台输入的解决方案,该方案适用于PTA平台上的题目要求。 #### 方法一:使用数组存储再逆向遍历打印 此方法涉及创建一个固定长度为10的数组来储存用户输入的十个整数,之后通过循环结构反向读取这些数值并依次显示出来[^1]。 ```java import java.util.Scanner; public class IntegerReverseOutput { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int[] numbers = new int[10]; // 输入阶段 for (int index = 0; index < numbers.length; ++index){ numbers[index] = scanner.nextInt(); } // 输出阶段 boolean isFirstElement = true; for (int position = numbers.length - 1; position >= 0 ; --position){ if (!isFirstElement){ System.out.print(", "); } System.out.print(numbers[position]); isFirstElement = false; } System.out.println(); // 结束后的行符 } } ``` 上述代码实现了接收一系列由用户提供的整数,并按照相反顺序展示给定序列的功能。特别注意的是,在连续两个数字间加入了逗号作为隔符,而最后一个元素后面不附加任何额外字符[^4]。 #### 方法二:单个大整数逐位拆反转 如果目标是从单一的大整数中提取每一位数字并将其按原位置相反的方向排列,则可考虑如下方式: ```java public class SingleIntegerReverse { private static void reversePrint(long num){ String strNum = Long.toString(num); StringBuilder reversedStrBuilder = new StringBuilder(strNum).reverse(); long reversedNumber = Long.parseLong(reversedStrBuilder.toString()); System.out.println(reversedNumber); } public static void main(String[] args) { reversePrint(123456789L); // 测试用例 } } ``` 这种方法适合于处理较大的单独整数而非多个独立的小整数集合的情况。它利用`StringBuilder`类内置的方法轻松完成字符串形式下的数字翻转操作[^2]。 对于更复杂的场景比如带有符号(-/+), 或者需要保留前导零等情况, 则可能还需要进一步调整逻辑以满足具体需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值