12. Integer to Roman(C++)

Given an integer, convert it to a roman numeral.

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

 

Solution:

以3999,为例:

class Solution {
public:
  string intToRoman(int num) {
    if(num<1||num>3999) return NULL;
    string str;
    while(num){
      if(num/1000!=0){
        for(int i=0;i<num/1000;i++) str+="M";
        num=num%1000;
      }else if(num/100!=0){
        int tmp=num/100;
        if(tmp%5==4){
          if(tmp/5==0){
            str+="C";str+="D";
          }else{  
            str+="C";str+="M";
          }
        }else{
          if(tmp/5!=0){
            str+="D";
          }
          for(int i=0;i<tmp%5;i++) str+="C";
        }
        num=num%100;
      }else if(num/10!=0){
        int tmp=num/10;
        if(tmp%5==4){
          if(tmp/5==0){
            str+="X";str+="L";
          }else{
            str+="X";str+="C";
          }
        }else{
          if(tmp/5!=0){
            str+="L";
          }
          for(int i=0;i<tmp%5;i++) str+="X";
        }
        num=num%10;
      }else{
        if(num%5==4){
          if(num/5==0){
            str+="I";str+="V";
          }else{
            str+="I";str+="X";
          }
        }else{
          if(num/5!=0){
            str+="V";
          }
          for(int i=0;i<num%5;i++) str+="I";
        }
        num=num%1;
      }
    }
    return str;
  }
};

posted @ 2017-03-03 11:26  DevinGu  阅读(268)  评论(0编辑  收藏  举报