zoukankan      html  css  js  c++  java
  • Integer to Roman

    题目

    Given an integer, convert it to a roman numeral.

    Input is guaranteed to be within the range from 1 to 3999.

    方法

    /*语法:
    *(1)基本数字I,X,C中的不论什么一个连用构成数目,都不能超过三个;
    *  放在大数的左边仅仅能用一个。


     (2)基本数字V ,L ,D 中的不论什么一个放在大数的右边採用相加的方式构成数目,仅仅能使用一个。


     (3)V 和X 左边的小数字仅仅能用I。


     (4)L 和C 左边的小数字仅仅能用X。


     (5)D 和M 左边的小数字仅仅能用C 。


     (6)在数字上加一横表示这个数字的1000倍。【因难以实现输入。临时忽略此要求】*/

    	    public String intToRoman(int num) {
    	        int digit;
    	        String str = "";
    	        int n = 10;
    	        while(num > 0){
    	            digit = num % n;
    	            switch(n){
    	                case 10:
    	                    switch(digit){
    	                        case 1:
    	                            str = "I" + str;
    	                            break;
    	                        case 2:
    	                            str = "II" + str;
    	                            break;
    	                        case 3:
    	                            str = "III" + str;
    	                            break;
    	                        case 4:
    	                            str = "IV" + str;
    	                            break;
    	                        case 5:
    	                            str = "V" + str;
    	                            break;
    	                        case 6:
    	                            str = "VI" + str;
    	                            break;     
    	                        case 7:
    	                            str = "VII" + str;
    	                            break;
    	                        case 8:
    	                            str = "VIII" + str;
    	                            break;   
    	                        case 9:
    	                            str = "IX" + str;
    	                            break;     
    	                        default:
    	                            break;
    	                    }
    	                    break;
    	                case 100:
    	                    digit = digit / 10;
    	                    switch(digit){
    	                        case 1:
    	                            str = "X" + str;
    	                            break;
    	                        case 2:
    	                            str = "XX" + str;
    	                            break;
    	                        case 3:
    	                            str = "XXX" + str;
    	                            break;
    	                        case 4:
    	                            str = "XL" + str;
    	                            break;
    	                        case 5:
    	                            str = "L" + str;
    	                            break;
    	                        case 6:
    	                            str = "LX" + str;
    	                            break;     
    	                        case 7:
    	                            str = "LXX" + str;
    	                            break;
    	                        case 8:
    	                            str = "LXXX" + str;
    	                            break;   
    	                        case 9:
    	                            str = "XC" + str;
    	                            break;   
    	                        default :break;
    	                    }
    	                    break;
    	                case 1000:
    	                    digit = digit / 100;
    	                    switch(digit){
    	                        case 1:
    	                            str = "C" + str;
    	                            break;
    	                        case 2:
    	                            str = "CC" + str;
    	                            break;
    	                        case 3:
    	                            str = "CCC" + str;
    	                            break;
    	                        case 4:
    	                            str = "CD" + str;
    	                            break;
    	                        case 5:
    	                            str = "D" + str;
    	                            break;
    	                        case 6:
    	                            str = "DC" + str;
    	                            break;     
    	                        case 7:
    	                            str = "DCC" + str;
    	                            break;
    	                        case 8:
    	                            str = "DCCC" + str;
    	                            break;   
    	                        case 9:
    	                            str = "CM" + str;
    	                            break;  
    	                        default :
    	                            break;
    	                    }
    	                    break;
    	                case 10000:
    	                    digit = digit / 1000;
    	                    switch(digit){
    	                        case 1:
    	                            str = "M" + str;
    	                            break;
    	                        case 2:
    	                            str = "MM" + str;
    	                            break;
    	                        case 3:
    	                            str = "MMM" + str;
    	                            break;
    	                  
    	                    }
    	                    break;
    	            }
    	            num = num - digit * n/10;
    	            n = n * 10;
    	        }
    	        return str;
    	    }


  • 相关阅读:
    HDU 2157 How many ways?【矩阵快速幂】
    CodeForces 3 D.Least Cost Bracket Sequence【贪心+优先队列】
    【差分】Tallest Cow
    P2220 [HAOI2012]容易题【快速幂】
    无题II HDU
    PHP编译常见错误
    MySQL编译安装
    Tomcat 单(多)实例部署使用
    lvs+keepalived 高可用及负载均衡
    MySQL操作命令梳理(2)
  • 原文地址:https://www.cnblogs.com/mqxnongmin/p/10522166.html
Copyright © 2011-2022 走看看