L1-017. 到底有多二(Java)PAT团体程序设计天梯赛-练习集

时间:2023-02-14 17:29:44

一个整数“犯二的程度”定义为该数字中包含2的个数与其位数的比值。如果这个数是负数,则程度增加0.5倍;如果还是个偶数,则再增加1倍。例如数字“-13142223336”是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11*1.5*2*100%,约为81.82%。本题就请你计算一个给定整数到底有多二。

输入格式:

输入第一行给出一个不超过50位的整数N。

输出格式:

在一行中输出N犯二的程度,保留小数点后两位。

输入样例:

-13142223336

输出样例:

81.82%


import java.util.Scanner;

public class Main {

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        char[] num = scanner.next().toCharArray();
        int len = num.length;
        double rate = 1;        // 倍数
        int i = 0, sum = 0; 

        // 如果是偶数,只看最后一位对2取余
        if (num[len - 1] % 2 == 0) {
            rate *= 2;
        }

        // 判断第一位是不是负号
        if (num[0] == '-') {
            rate *= 1.5;
            i++;    // 数字索引后移
            len--;  // 数字长度减一
        }

        // 统计有多少个 '2'
        while (i < num.length) {
            if (num[i] == '2') {
                sum++;
            }
            i++;
        }

        double result = 100 * rate * sum / len;
        System.out.printf("%.2f%%", result);
        //System.out.print("%");
    }
}