• PAT(B) 1017 A除以B(Java)


    题目链接:1017 A除以B
    分析
    • 读取输入的A和B后,保存为字符串。模拟除法运算过程。
    • 不要用BigInteger,因为会超时
    • 另外字符串经常要扩展(例如:append())的话,不要用String(非常慢),用StringBuilder是上上策。
    • 最后要注意,如果结果的第一位是0,并且只有一位,那么输出0,否则输出去掉首位后的结果。
    /**
     * Score 20
     * Run Time 80ms
     * @author 柳婼 https://blog.csdn.net/liuchuo/article/details/56676450#commentBox
     * @version 2.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[] ab = br.readLine().split(" ");// 读取输入的A和B到ab[0]和ab[1]
    		br.close();
    
    		int b = Integer.parseInt(ab[1]);// 获取B
    		int temp = 0;// 除法运算的临时变量
    
    		StringBuilder sb = new StringBuilder();// 保存结果
    
    		// 模拟除法运算过程
    		for (int i = 0; i < ab[0].length(); i++) {
    			temp = temp * 10 + ab[0].charAt(i) - '0';// 当前步骤的被除数
    			sb.append((char) (temp / b + '0'));// 当前步骤的商添加到结果的末尾
    			temp = temp % b;// 当前步骤的余数
    		}
    
    		String result = sb.toString();
    
    		// 第一位可能为0,为0去掉
    		if (result.charAt(0) == '0' && result.length() != 1) {
    			System.out.print(result.substring(1) + " " + temp);
    		} else {
    			System.out.print(result + " " + temp);
    		}
    	}
    }
    
  • 相关阅读:
    【MySQL】悲观锁&乐观锁
    选盘秘籍:用户如何选择SSD/SATA/SAS?
    【MySQL】分页优化
    【MySQL】锁问题最佳实践
    【MySQL】锁入门
    【MySQL】SQL优化系列之 in与range 查询
    【DNS】简单聊聊DNS如何工作
    【MySQL】排序原理与案例分析
    git的使用
    关于fastjson与jackson在反序列化bool型时的区别
  • 原文地址:https://www.cnblogs.com/wowpH/p/11060779.html
Copyright © 2020-2023  润新知