Problem G 1217 A+B VII

2021年下学期《C语言程序设计》作业10-2013年下学期期末考试

Description

题目描述

小明非常高兴你能帮他处理那些罗马数字,他想学着自己写罗马数字,但是他不知道自己到底写对了没有。 请你帮他写个程序,能正确地将10进制数字转换成罗马数字,以便他能进行核对。 罗马数字是使用字母组合表示数字的。不同的字母表示的值如下表:

字母
I1
V5
X10
L50
C100
D500
M1000
表示规则如下:
  • 数字的值是为所有字母的值的和。比如说II=2,XIII=13
  • 没有0,比如207使用两个100,1个5,2个1表示,即CCVII
  • 字母应该按值的降序从左到右排列,但为了避免太多的重复(比如IIII),使用减法来缩短式子
    1. 使用I在V和X前,表示4(IV)和9(IX)
    2. 使用X在L和C前,表示40(XL)和90(XC)
    3. 使用C在D和M前,表示400(CD)和900(CM)

输入

每行输入一个整数n,1≤n≤10,000。

输出

每行输出对应十进制整数的罗马数字。

这个题思路很简单,照着题意模拟就行。

#include<stdio.h> //坑 
//#include<math.h>  //坑 
//#include<algorithm>
using namespace std;
int main() {
    int n;
    while (scanf("%d", &n) != EOF) {
        int cache;
        
        cache = n / 1000;
        for (int i = 1; i <= cache; i++) {
            printf("M");
            n -= 1000;
        }
        if (n >= 900) {
            printf("CM");
            n -= 900;
        }
        
        
        
        cache = n / 500;
        for (int i = 1; i <= cache; i++) {
            printf("D");
            n -= 500;
        }
        if (n >= 400) {
            printf("CD");
            n -= 400;
        }
        
        
        
        cache = n / 100;
        for (int i = 1; i <= cache; i++) {
            printf("C");
            n -= 100;
        }
        if (n >= 90) {
            printf("XC");
            n -= 90;
        }
        
        
        
        cache = n / 50;
        for (int i = 1; i <= cache; i++) {
            printf("L");
            n -= 50;
        }
        if (n >= 40) {
            printf("XL");
            n -= 40;
        }
        
        
        
        cache = n / 10;
        for (int i = 1; i <= cache; i++) {
            printf("X");
            n -= 10;
        }
        if (n >= 9) {
            printf("IX");
            n -= 9;
        }
        
        
        
        cache = n / 5;
        for (int i = 1; i <= cache; i++) {
            printf("V");
            n -= 5;
        }
        if (n >= 4) {
            printf("IV");
            n -= 4;
        }
        
        
        
        cache = n / 1;
        for (int i = 1; i <= cache; i++) {
            printf("I");
        }
        puts("");
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SQ_ZYX

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值