十进制数转罗马数字 – Switch笨方法解题

导读:本篇文章讲解 十进制数转罗马数字 – Switch笨方法解题,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Y9qw1Jjc-1576562042415)(en-resource://database/13503:1)]

  数字转罗马数字工具类

class NumberChange {

	public static String reverseStr(String str) {
		StringBuilder sb = new StringBuilder();
		int index = str.length() - 1;
		for (int i = index; i >= 0; i--) {
			sb.append(str.substring(i, i + 1));
		}
		return sb.toString();
	}

	public static String currentLocationInvert( String number , Integer zeroCount) {
		
		Integer num = Integer.parseInt(number);
		StringBuilder sb = new StringBuilder();
		switch(zeroCount) {
			case 0 : {
				
				 if(num<4) {
						for(int i = 0; i < num; i++) {
							sb.append("I");
						}
				}else if(num == 4) {
						sb.append("IV");
				}else if(num == 5) {
						sb.append("V");
				}else if(num == 9) {
						sb.append("IX");
				}else {
						sb.append("V");
						for(int i = 0; i<num-5; i++) {
							sb.append("I");
						}
					}
				 break;
			}
				
			case 1 :  {
				
				 if(num<4) {
						for(int i = 0; i < num; i++) {
							sb.append("X");
						}
				}else if(num == 4) {
						sb.append("XL");
				}else if(num == 5) {
						sb.append("L");
				}else if(num == 9) {
						sb.append("XC");
				}else {
						sb.append("L");
						for(int i = 0; i<num-5; i++) {
							sb.append("X");
						}
					}
				 break;
			}
			case 2 :   {
				
				 if(num<4) {
						for(int i = 0; i < num; i++) {
							sb.append("C");
						}
				}else if(num == 4) {
						sb.append("CD");
				}else if(num == 5) {
						sb.append("D");
				}else if(num == 9) {
						sb.append("CM");
				}else {
						sb.append("D");
						for(int i = 0; i<num-5; i++) {
							sb.append("C");
						}
					}
				 break;
			}
			case 3  : {
				for(int i = 0; i < num; i++) {
					sb.append("M");
				}
			}
		}

	return sb.toString();

	}

	public static String invertToRoman(Integer number) {
		
		// 1. 只转 1-3999范围的数字
		if(number<1 || number > 3999) {
			throw new RuntimeException("请输入在【1~3999】范围内的数字 - 小老弟别搞事");
		}
		
		// 2. 将数字倒序
		String strNum = reverseStr(number.toString());
		
		// 3. 定义一个字符输出对象
		StringBuilder sb = new StringBuilder();
		
		// 4. 遍历输出 - 打印
		for(int i = strNum.length()-1; i>=0; i--) {
			String num = strNum.substring(i,i+1);
			String roma = currentLocationInvert(num, i);
			sb.append(roma);
		}
		
		// 5. 返回结果
		return sb.toString();
	}

}


  测试代码

public static void main(String[] args) {
    System.out.println(NumberChange.invertToRoman(1994));
    System.out.println(NumberChange.invertToRoman(58));
    System.out.println(NumberChange.invertToRoman(9));
    System.out.println(NumberChange.invertToRoman(4));
    System.out.println(NumberChange.invertToRoman(3));
}

  输出结果
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ITWUZBSR-1576562042423)(en-resource://database/13505:1)]


看了这篇推文解题,我不禁发出一句卧槽,居然还能那么简单
https://www.cnblogs.com/mxwbq/p/10956786.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/46533.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!