• LeetCode题解 #12 Integer to Roman


    题目大意:给定数字,将其转化为罗马数字的形式

    罗马数字其实只有 I V X L C D M 这几种形式,其余均为组合的,去百度了解一下就ok。

    所以首先想到的就是,将个、十、百、千位的数字构造出来,然后直接用就好了。

    要特别注意为整10,整100、1000的情况。

    String [] ge ={"I","II","III","IV","V","VI","VII","VIII","IX"};

    String [] shi = {"X","XX","XXX","XL","L","LX","LXX","LXXX","XC"};

    String [] bai = {"C","CC","CCC","CD","D","DC","DCC","DCCC","CM"};

    String [] qian = {"M","MM","MMM"};


    public String intToRoman(int num) {


    String result = "";
    String g = "";
    String s = "";
    String b = "";
    String q = "";



    if(num%10>0){
    g = ge[num%10-1];
    num/=10;}else{

    g="";
    num/=10;
    }



    if(num>0){

    if(num%10>0){
    s = shi[num%10-1];
    num/=10;}else{

    s="";
    num/=10;
    }

    if(num>0){

    if(num%10>0){
    b = bai[num%10-1];
    num/=10;}else{

    b="";
    num/=10;
    }

    if(num>0){

    q=qian[num%10-1];
    num/=10;

    return q+b+s+g;


    }
    else{

    return b+s+g;

    }


    }
    else{

    return s+g;

    }



    }
    else
    return g;


    }

    更精简的代码(将整10、100、1000的情况整合到数组里面)

    string intToRoman(int num) {

    string roman[4][10] = {

    {"", "I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX"},

    {"", "X", "XX", "XXX", "XL", "L", "LX", "LXX", "LXXX", "XC"},

    {"", "C", "CC", "CCC", "CD", "D", "DC", "DCC", "DCCC", "CM"},

    {"", "M", "MM", "MMM"}

    };

    string ret = "";

    int digit = 0;

    while (num)

    {ret = roman[digit++][num % 10] + ret, num /= 10; return ret; }

  • 相关阅读:
    欢迎使用CSDN-markdown编辑器
    欢迎使用CSDN-markdown编辑器
    Math类简介
    Math类简介
    http_server
    tcp服务器
    swoole安装
    laravel源码解析
    VMware的Unity模式
    string.format() %d越界的问题
  • 原文地址:https://www.cnblogs.com/wzben/p/5017982.html
Copyright © 2020-2023  润新知