• Java实现 蓝桥杯VIP 算法提高 乘法运算


    算法提高 乘法运算
    时间限制:1.0s 内存限制:512.0MB
    问题描述
      编制一个乘法运算的程序。
      从键盘读入2个100以内的正整数,进行乘法运算并以竖式输出。
    输入格式
      输入只有一行,是两个用空格隔开的数字,均在1~99之间(含1和99)。
    输出格式
      输出为4行或7行,符合乘法的竖式运算格式。
    样例输入
    89 13
    样例输出
    89
    ×13
    ━━━
    267
    89
    ━━━
    1157
    输入输出样例1解释
      3×89=267,则第四行267右侧对准个位输出。1×89=89,则第五行89右侧对准十位输出。267+890=1157,则1157右侧对准个位输出。
    样例输入
    16 8
    样例输出
    16
    × 8
    ━━━
    128
    输入输出样例2解释
      8×16=128,则第四行128右侧对准个位输出。计算完成,不再输出。

    import java.util.Scanner;
    
    
    public class 乘法运算 {
    	private static Scanner scanner = new Scanner(System.in);
    
    	public static void main(String[] args) {
    		int c1 = scanner.nextInt();
    		int c2 = scanner.nextInt();
    		String s = String.valueOf(c1 * c2);
    		int len = s.length();
    		char[] cs = c2 < 10 ? String.valueOf(" " + c2).toCharArray() : String
    				.valueOf(c2).toCharArray();
    		System.out.println(c1 + "
    u00D7" + String.valueOf(cs)
    				+ "
    u2501u2501u2501");
    		if (c2 >= 10) {
    			for (int i = cs.length - 1; i >= 0; i--) {
    				if (cs[i] != ' ') {
    					String x = String.valueOf(c1 * (cs[i] - '0'));
    					if (x.equals("0"))  
    						x = "00"; 
    					for (int j = 1; j < cs.length - i; j++)
    						x += " ";
    					int l = x.length();
    					for (int j = 0; j < len - l; j++)
    						x = " " + x;
    					System.out.println(x);
    				}
    			}
    			System.out.println("u2501u2501u2501");
    		}
    		System.out.println(s);
    	}
    
    }
    
    
  • 相关阅读:
    BZOJ 2574: [Poi1999]Store-Keeper
    BZOJ 1024: [SCOI2009]生日快乐
    BZOJ 2541: [Ctsc2000]冰原探险
    hihoCoder 1303 数论六·模线性方程组
    Codeforces 710 D. Two Arithmetic Progressions
    BZOJ 1670: [Usaco2006 Oct]Building the Moat护城河的挖掘
    ZJOI2014 2048
    51Nod 1766 树上的最远点对
    Codeforces 727 F. Polycarp's problems
    BZOJ 3736: [Pa2013]Karty
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13078273.html
Copyright © 2020-2023  润新知