数字转换 转成罗马数字

原创 2012年06月06日 22:21:07

数据转换:输入一个数,0<数<1000;
1  2   3    4   5   6   7    8     9
I  II  III  IV  V   VI  VII  VIII  IX
10  20  30  40  50   60   70   80   90
X   XX  XXX XL  L    LX   LXX  LXXX  XLL
100  200  300  400  500  600    700   800  900
C    CC   CCC  CD   D    DC    DCC  DCCC  CM
示例:
输入: 863
输出:DCCCLXIII

 

代码实现:

#include<iostream>
using namespace std;

int main()
{   cout<<"请输入一个1~999之间的整数:"<<endl;
 int m;
 //对输入数据进行检查,如果输入数据不合要求则反复要求继续输入一数据,直到数据合法
 do{
 cin>>m;
 if(m<0||m>999)
 { cout<<"输入数据错误,请重新输入。"<<endl;
 }
 }while(m<0||m>999);
 int ge=0,shi=0,bai=0; 
 bai=(m/100);          //取得输入数的百位数字
 shi=(m/10)-bai*10;    //取得输入数的十位数字
 ge=m%100-shi*10;       //取得输入数的个位数字
 int array[3];        //定义一个数组存入该输入数的百,十,个
 array[0]=bai*100;
 array[1]=shi*10;
 array[2]=ge;
 void Change(int a[]);
 Change(array);
    return 0;
}

void Change(int a[])

 for(int i=0;i<3;i++)
 switch(a[i])
 {
  case 1:cout<<"I";break;
  case 2:cout<<"II";break;
  case 3:cout<<"III";break;
  case 4:cout<<"IV";break;
  case 5:cout<<"V";break;
  case 6:cout<<"VI";break;
  case 7:cout<<"VII";break;
  case 8:cout<<"VIII";break;
  case 9:cout<<"IX";break;
  case 10:cout<<"X";break;
  case 20:cout<<"XX";break;
  case 30:cout<<"XXX";break;
  case 40:cout<<"XL";break;
  case 50:cout<<"L";break;
  case 60:cout<<"LX";break;
  case 70:cout<<"LXX";break;
  case 80:cout<<"LXXX";break;
  case 90:cout<<"XC";break;
  case 100:cout<<"C";break;
  case 200:cout<<"CC";break;
  case 300:cout<<"CCC";break;
  case 400:cout<<"CD";break;
  case 500:cout<<"D";break;
  case 600:cout<<"DC";break;
  case 700:cout<<"DCC";break;
  case 800:cout<<"DCCC";break;
  case 900:cout<<"CM";break;
  default:break;
  }
  
}

 

相关文章推荐

[LeetCode-13] Roman to Integer(罗马数字转成阿拉伯数字)

不难发现,罗马数字是没有禁止,我建议大家可以先试着从I数到C,这样便对罗马数字有个了解,然后发现其为纯粹叠加而成的,所以用户输入一个数后,我们可以来遍历这个数,用sum来总计和,比较pre (s[i-...

leetcode-java.T013_RomarToInteger 罗马数字转成整数数字

每天坚持刷leetcode----罗马数字转整数数字: package leetcode.T013_RomarToInteger; /** * @Title: Solution.java ...

12.整形数字转换为罗马数字

Integer to Roman问题描述:Given an integer, convert it to a roman numeral.Input is guaranteed to be withi...

对一个罗马数字与阿拉伯数字转换算法的分析

分析一个阿拉伯数字到罗马数字的转换算法。

Python 罗马数字与阿拉伯数字的转换

原文https://kingname.info/2014/12/29/%E5%AF%B9%E4%B8%80%E4%B8%AA%E7%BD%97%E9%A9%AC%E6%95%B0%E5%AD%97%E...

分析、测试与总结:罗马数字和阿拉伯数字的转换[roman to integer and integer to roman in c++]

【本文链接】 http://www.cnblogs.com/hellogiser/p/roman-to-integer-and-integer-to-roman.html 【题目】 ...

罗马数字与阿拉伯数字相互转换

罗马数字规则简明 1. 罗马单个数字共有7个,即I(1)、V(5)、X(10)、L(50)、C(100)、D(500)和M(1000) 2.一个罗马数字重复几次,就表示这个数的几倍。但同一数码...

C++罗马数字与十进制数字互相转换

罗马数字与十进制数字转化c++代码

Java经典题:罗马数字和阿拉伯数字的相互转换

古罗马帝国开创了辉煌的人类文明,但他们的数字表示法的确有些繁琐,尤其在表示大数的时候,现在看起来简直不能忍受,所以在现代很少使用了。之所以这样,不是因为发明表示法的人的智力的问题,而是因为一个宗教的原...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数字转换 转成罗马数字
举报原因:
原因补充:

(最多只允许输入30个字)