XTU OJ 1217 A+B

31 篇文章 2 订阅

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。

输出

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

样例输入

1
2
3
4
9999
10000

样例输出

I
II
III
IV
MMMMMMMMMCMXCIX
MMMMMMMMMM

思路分析:分类讨论就完事了 

 

#include<stdio.h>
#include <iostream>

int main()
{
	int n;
	int count, count2;
	int temp;
	while (scanf("%d", &n) != EOF) {


		if (n>=1000) {
			count = n / 1000;
			for (int i = 0; i < count; i++) {
				printf("M");
			}
			n = n - (count * 1000);
		}
		 if(n>=900&&n<1000)
		{
			 printf("CM");
			count = n / 100;
			n = n - (count * 100);
		}
		 else if (n >= 500 && n < 900) {
			 printf("D");
			 count = n / 100;
			 count2 = count - 5;
			 for (int i = 0; i < count2; i++) {
				 printf("C");
			 }
			 n = n - (count * 100);
		 }
		 else if (n >= 400 && n < 500) {
			 printf("CD");
			 n = n - 400;
		 }
		 else if (n >= 100 && n < 400) {
			 count = n / 100;
			 for (int i = 0; i < count; i++) {
				 printf("C");
			 }
			 n = n - (count * 100);
		 }
		 if (n >= 90 && n < 100) {
			 printf("XC");
			 n = n - 90;
		 }
		 else if (n >= 50 && n < 90) {
			 printf("L");
			 count = n / 10;
			 count2 = count - 5;
			 for (int i = 0; i < count2; i++) {
				 printf("X");
			 }
			 n = n - (count * 10);
		 }
		 else if (n >= 40 && n < 50) {
			 printf("XL");
			 n = n - 40;
		 }
		 else if (n >= 10 && n < 40) {
			 count = n / 10;
			 for (int i = 0; i < count; i++) {
				 printf("X");
			 }
			 n = n - (count * 10);
		 }
		 if (n == 9) {
			 printf("IX");
		 }
		 else if (n >= 5 && n < 9) {
			 printf("V");
			 count2 = n - 5;
			 for (int i = 0; i < count2; i++) {
				 printf("I");
			 }
		 }
		 else if (n == 4) {
			 printf("IV");
		 }
		 else if (n >= 1 && n < 4) {
			 for (int i = 0; i < n; i++) {
				 printf("I");
			}
			 

			 
		 }
		 printf("\n");

	
		
	}
  
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值