赛码网——约德尔测试

题目

兰博和提莫闲聊之后,回归到了他们的正题,约德尔人的未来。

说起约德尔人的未来,黑默丁格曾经提出了一个约德尔测试,将约德尔人的历史的每个阶段都用一个字符表达出来。(包括可写字符,不包括空格。)。然后将这个字符串转化为一个01串。转化规则是如果这个字符如果是字母或者数字,这个字符变为1,其它变为0。然后将这个01串和黑默丁格观测星空得到的01串做比较,得到一个相似率。相似率越高,则约德尔的未来越光明。

请问:相似率为多少?
赛码网——约德尔测试_第1张图片

解题思路

这道题目本身不难,但细节处理上需要注意,主要有以下几点:

  1. 题目要求计算结果保留两位小数,这里使用输出时控制格式的方法
    System.out.printf(String.format("%.2f", rate));
  2. 根据题目提示输出百分号的方法
    System.out.printf("%%");
  3. 须将统计字符相同的变量设置为double类型,如使用int类型做计算,结果只保留整数部分。

代码

import java.util.*;
public class Main{
    public static void main(String[] args){
        Scanner scanner = new Scanner(System.in);
        String history = scanner.next();
        String star = scanner.next();
        double count = 0.0;
        double hlength = history.length();
        
        for (int i = 0; i < hlength; i++){
            char tmp = history.charAt(i);
            char starchar = star.charAt(i);
            if ((tmp >= 'a' && tmp <= 'z') || (tmp >= 'A' && tmp <= 'Z') || (tmp >= '0' && tmp <= '9')){
                if (starchar == '1') {
                    count = count + 1;
                }
            }else{
                if (starchar == '0') {
                    count = count + 1;
                }
            }
        }
        
        System.out.printf(String.format("%.2f" , (count * 100.0) / hlength));
        System.out.printf("%%");
    }
}

你可能感兴趣的:(赛码网)