• 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));// 输出个数
    		}
    	}
    }
    

    提交结果

    提交结果

  • 相关阅读:
    【转】sql 如何设计数据库表实现完整的RBAC(基于角色权限控制)
    【转】windows自带终止进程的超强命令
    【源码】 gridview 里使用checkbox
    【转】调用 开始 运行 直接执行命令
    【源码】DropDownList绑定数据
    C++ 编译器数据类型差异
    Flash 中将不透明的 Bitmap 透明化处理
    使用命令行切换IP地址
    MKV 高清视频文件分解与封装和音频编码的转换
    Visual Studio 2010 C++ 用户属性设置
  • 原文地址:https://www.cnblogs.com/wowpH/p/11687437.html
Copyright © 2020-2023  润新知