阿拉伯数字转罗马数字

链接:https://ac.nowcoder.com/acm/contest/637/A
来源:牛客网

时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld
题目描述
张老师需要用数字来统计学生们的得分情况,但阿拉伯数字已经不能满足他的要求了,所以想请你帮忙将学生的成绩转换成罗马数字。
罗马数字是由七个不同的符号来表示(I,V,X,L,C,D和M),其中每个符号对应的值如下表
符号 值
I 1
V 5
X 10
L 50
C 100
D 500
M 1000
罗马数字通常从左到右从最大写到最小,表示他们的总和。但是,数字4的罗马数字表示不是IIII,而是IV,表示5-1=4。同样的,有6个应用相同原理的规则:
I可以放在V(5)和X(10)之前代表4和9。
X可以在L(50)和C(100)之前代表40和90。
C可以放在D(500)和M(1000)之前代表400和900。
现在给定一个整数,张老师请你计算出其罗马数字的表示。

输入描述:
第一行一个整数x(1<=x<=2000)
输出描述:
输出一行,表示整数x所对应的罗马数字表示
示例1
输入
复制
5
输出
复制
V
示例2
输入
复制
1926
输出
复制
MCMXXVI

#include <iostream>
#include <string>
using namespace std;
class Solution {//C++ 类的使用
public://公共
    string zhuan(int num) {
        string solution;
        string roman[]={"M","CM","D","CD","C","XC","L","XL","X","IX","V","IV","I"};  //将罗马字符与数字对应
        int value[]=    {1000,900,500,400, 100, 90,  50, 40,  10, 9,   5,  4,   1};
        for(int i=0;num!=0;++i)
        {
            while(num>=value[i])
            {
                num-=value[i];  //将输入的数字减去罗马字符代表的最大的数值
                solution+=roman[i]; //将减去的数值代表的罗马符号加入字符串
            }
        }
        return solution;
    }
};
int main(){
    Solution solu;
    int number;
    cin>>number;
    string s=solu.zhuan(number);
    cout<<s<<endl;
}

#include <iostream>
#include <string>
#include <vector>
using namespace std;
string intToRoman_simple(int num){
    int values[] = { 1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1 };
    string numerals[] = { "M", "CM", "D", "CD", "C", "XC", "L", "XL", "X", "IX", "V", "IV", "I" };
    string str = "";
    for (int i = 0; i < sizeof(values) / sizeof(values[0]); i++){
        string str_t = "";
        while (num >= values[i]){
            num -= values[i];
            str_t += numerals[i];
        }
        str += str_t;
    }
    return str;
}
string intToRoman(int num){
    string str = "";
    string roman[7] = { "I", "V", "X",
        "L", "C", "D", "M" };
    int j = 0;
    while (num){
        string str_t = "";
        int temp = num % 10;
        if (temp < 4){
            int count = temp;
            while (count--){
                str_t += roman[j];
            }
        }
        else if (temp == 4){
            str_t += roman[j];
            str_t += roman[j + 1];
        }
        else if (temp >= 5 && temp <= 8){
            str_t += roman[j + 1];
            int count = temp - 5;
            while (count--){
                str_t += roman[j];
            }
        }
        else{
            str_t += roman[j];
            str_t += roman[j + 2];
        }
        str = str_t + str;
        cout << str_t << endl;
        cout << str << endl;
        num /= 10;
        j = j + 2;
    }
    return str;

}
int main(){
    int t;
    cin>>t;
    cout << intToRoman_simple(t) << endl;
    return 0;
}
全部评论

相关推荐

11-30 11:07
河南大学 Java
宇宙厂 测开 n*15
丘丘给个offer:有后选后
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务