蓝桥杯

1.罗马数字

2019-03-23  本文已影响2人  wxy_7fa5

问题描述

古罗马帝国开创了辉煌的人类文明,但他们的数字表示法的确有些繁琐,尤其在表示大数的时候,现在看起来简直不能忍受,所以在现代很少使用了。之所以这样,不是因为发明表示法的人的智力的问题,而是因为一个宗教的原因,当时的宗教禁止在数字中出现 0 的概念!罗马数字的表示主要依赖以下几个基本符号:
I --> 1
V --> 5
X --> 10
L --> 50
C --> 100
D --> 500
M --> 1000
这里,我们只介绍一下 1000 以内的数字的表示法。
单个符号重复多少次,就表示多少倍。最多重复 3 次。

​ 比如:CCC 表示 300 XX 表示 20,但 150 并不用 LLL 表示,这个规则仅适用于 I X C M。
​ 如果相邻级别的大单位在右,小单位在左,表示大单位中扣除小单位。比如:IX 表示 9,IV 表示 4,XL 表示 40,49 = XLIX。

​ 更多的示例参见下表,你找到规律了吗?
​ I = 1
​ II = 2
​ III = 3
​ IV = 4
​ V = 5
​ VI = 6
​ VII = 7
​ VIII = 8
​ IX = 9
​ X = 10
​ XI = 11
​ XII = 12
​ XIII = 13
​ XIV = 14
​ XV = 15
​ XVI = 16
​ XVII = 17
​ XVIII = 18
​ XIX = 19
​ XX = 20
​ XXI = 21
​ XXII = 22
​ XXIX = 29
​ XXX = 30
​ XXXIV = 34
​ XXXV = 35
​ XXXIX = 39
​ XL = 40
​ L = 50
​ LI = 51
​ LV = 55

​ LX = 60
​ LXV = 65
​ LXXX = 80
​ XC = 90
​ XCIII = 93
​ XCV = 95
​ XCVIII = 98
​ XCIX = 99
​ C = 100
​ CC = 200
​ CCC = 300
​ CD = 400
​ D = 500
​ DC = 600
​ DCC = 700
​ DCCC = 800
​ CM = 900
​ CMXCIX = 999
​ 本题目的要求是:请编写程序,由用户输入若干个罗马数字串,程序输出对应的十进制表示。
​ 输入格式是:第一行是整数 n,表示接下来有 n 个罗马数字(n<100)。以后每行一个罗马数字。罗马数字大小不超过 999。要求程序输出 n 行,就是罗马数字对应的十进制数据。
​ 例如,用户输入:
​ 3
​ LXXX
​ XCIII
​ DCCII
​ 则程序应该输出:
​ 80
​ 93
​ 702

思路

难点一:小单位在大单位左边这种情况,而且还不是所有小单位放到大单位左边都成立。
需要单独考虑的有下面几种情况:
IV
IX
XL
XC
CD
CM
难点二:输入的罗马数字不正确,如先

public class RomeNum {
    /*
     * 把输入的阿拉伯数字变成罗马数字
     */
    static String numRoman(int x){
            int a = x/1000;
            int b = x%1000/100;
            int c = x%100/10;
            int d = x%10;   
            String s = "";
            if(a==1) s += "M"; //a等于0,s不变
            if(a==2) s += "MM";
            if(a==3) s += "MMM";//就考虑3000范围内的
            if(b==1 ) s += "C";
            if(b==2 ) s += "CC";
            if(b==3 ) s += "CCC";
            if(b==4 ) s += "CD";
            if(b==5 ) s += "D";
            if(b==6 ) s += "DC";
            if(b==7 ) s += "DCC";
            if(b==8 ) s += "DCCC";
            if(b==9 ) s += "CM";
            if(c==1 ) s += "X";
            if(c==2 ) s += "XX";
            if(c==3 ) s += "XXX";
            if(c==4 ) s += "XL";
            if(c==5 ) s += "L";
            if(c==6 ) s += "LX";
            if(c==7 ) s += "LXX";
            if(c==8 ) s += "LXXX";
            if(c==9 ) s += "XC";
            if(d==1 ) s += "I";
            if(d==2 ) s += "II";
            if(d==3 ) s += "III";
            if(d==4 ) s += "IV";
            if(d==5 ) s += "V";
            if(d==6 ) s += "VI";
            if(d==7 ) s += "VII";
            if(d==8 ) s += "VIII";
            if(d==9 ) s += "IX";
            return s;
        }
    /*
     * 判断罗马数字是否正确
     */
    static boolean romanNumOk(String s){
        for(int i=0;i<4000;i++){
            if(s.equals(numRoman(i))) return true;
        }
        return false;
    }
    /*
     * 把输入的罗马数字变成阿拉伯数字
     */
    public static int romanNum(String s){
        int sum = 0;
        //先从各位相加
        for(int i=0;i<s.length();i++){
            char c = s.charAt(i);
            if(c=='I') sum += 1;
            if(c=='V') sum += 5;
            if(c=='X') sum += 10;
            if(c=='L') sum += 50;
            if(c=='C') sum += 100;
            if(c=='D') sum += 500;
            if(c=='M') sum += 1000;     
        }
        //补偿
        if(s.indexOf("IV")>=0) sum -= 2;
        if(s.indexOf("IX")>=0) sum -= 2;
        if(s.indexOf("XL")>=0) sum -= 20;
        if(s.indexOf("XC")>=0) sum -= 20;
        if(s.indexOf("CD")>=0) sum -= 200;
        if(s.indexOf("CM")>=0) sum -= 200;  
        //若写的不是合法的罗马数字串 
        return sum;
    }
    public static void main(String[] args) {    
        System.out.println(romanNumOk("MCCCXIV"));
        //      System.out.println(numRoman(3249));
    }
}
上一篇下一篇

猜你喜欢

热点阅读