链接:https://ac.nowcoder.com/acm/contest/637/A
来源:牛客网
Problem Description:
张老师需要用数字来统计学生们的得分情况,但阿拉伯数字已经不能满足他的要求了,所以想请你帮忙将学生的成绩转换成罗马数字。
罗马数字是由七个不同的符号来表示(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。
现在给定一个整数,张老师请你计算出其罗马数字的表示。
Input:
第一行一个整数x(1<=x<=2000)
Output:
输出一行,表示整数x所对应的罗马数字表示
Sample Input 1:
5
Sample Output 1:
V
Sample Input 2:
1926
Sample Output 2:
MCMXXVI
思路: 穷举
My Code:
#include<iostream>
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<queue>
#include<math.h>
#include<set>
using namespace std;
#define INF 1e9
typedef long long ll;
int main()
{
int x;
cin >> x;
while(x)
{
if(x/1000 != 0)
{
int a = x/1000;
for(int i = 0; i < a; i++)
printf("M");
x %= 1000;
}
else if(x/100 != 0)
{
int a = x/100;
if(a == 1) printf("C");
else if(a == 4) printf("CD");
else if(a == 5) printf("D");
else if(a == 9) printf("CM");
else if(a > 1 && a < 4)
{
for(int i = 0; i < a; i++)
printf("C");
}
else if(a > 5 &&a < 9)
{
printf("D");
for(int i = 0; i < a-5; i++)
printf("C");
}
x %= 100;
}
else if(x/10 != 0)
{
int a = x/10;
if(a == 1) printf("X");
else if(a == 4) printf("XL");
else if(a == 5) printf("L");
else if(a == 9) printf("XC");
else if(a > 1 && a < 4)
{
for(int i = 0; i < a; i++)
printf("X");
}
else if(a > 5 &&a < 9)
{
printf("L");
for(int i = 0; i < a-5; i++)
printf("X");
}
x %= 10;
}
else
{
if(x == 1) printf("I");
else if(x == 4) printf("IV");
else if(x == 5) printf("V");
else if(x == 9) printf("IX");
else if(x > 1 && x < 4)
{
for(int i = 0; i < x; i++)
printf("I");
}
else if(x > 5 &&x < 9)
{
printf("V");
for(int i = 0; i < x-5; i++)
printf("I");
}
x %= 1;
}
}
cout << endl;
return 0;
}