PAT(B) 1057 数零壹(Java)字符串

题目链接:1057 数零壹 (20 point(s))

题目描述

给定一串长度不超过 10​5​​ 的字符串,本题要求你将其中所有英文字母的序号(字母 a-z 对应序号 1-26,不分大小写)相加,得到整数 N,然后再分析一下 N 的二进制表示中有多少 0、多少 1。例如给定字符串 PAT (Basic),其字母序号之和为:16+1+20+2+1+19+9+3=71,而 71 的二进制是 1000111,即有 3 个 0、4 个 1。

输入格式

输入在一行中给出长度不超过 10​5​​、以回车结束的字符串。

输出格式

在一行中先后输出 0 的个数和 1 的个数,其间以空格分隔。

测试样例

Case 0:

PAT (Basic)
3 4

Case 1:

aBd
0 3

Case 2:

615
0 0

Java代码

/**********************************************************************************
Submit Time			Status		Score	Problem	Compiler		Run Time	User
8/3/2019, 10:43:00	Accepted	20		1057	Java (openjdk)	163 ms		wowpH
Case 1: '0'的个数为0,'1'的个数大于0
Case 2: '0'的个数为0,'1'的个数为0
**********************************************************************************/
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class Main {
	public static void main(String[] args) throws IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		String str = br.readLine().replaceAll("[^a-zA-Z]", "");// 去掉非字母字符
		char[] letter = str.toUpperCase().toCharArray();	// 转成大写后转成数组

		int sum = letter.length * (-64);					// 'A'的ASCII码值为65
		for (int i = 0; i < letter.length; ++i) {
			sum += letter[i];								// 计算和sum
		}

		if (0 == sum) {										// 和为0
			System.out.println(0 + " " + 0);
		} else {											// 和不为0
			String bs = Integer.toBinaryString(sum);		// sum的二进制串
			int zeroNum = bs.replaceAll("1", "").length();// 去掉'1',得到'0'的个数
			System.out.println(zeroNum + " " + (bs.length() - zeroNum));// 输出个数
		}
	}
}

提交结果

提交结果

posted @ 2019-08-03 12:54  wowpH  阅读(185)  评论(0编辑  收藏  举报