数字转换 转成罗马数字

原创 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;
  }
  
}

 

罗马数字转换为十进制数字

给定一个罗马数字s,( I
  • u010002184
  • u010002184
  • 2016年02月25日 18:39
  • 1194

python解leetcode——13.Roman to Integer (罗马数字转为整数)

(来自百度百科)罗马数字是阿拉伯数字传入之前使用的一种数码。罗马数字采用七个罗马字母作数字、即Ⅰ(1)、X(10)、C(100)、M(1000)、V(5)、L(50)、D(500)。记数的方法: ...
  • yayh2011
  • yayh2011
  • 2017年05月01日 22:41
  • 455

Leetcode#13. Roman to Integer (罗马数字转化阿拉伯数字)

xuna小记:题目解法使用c++和Python两种,重点侧重在于解题思路和如何将解法用python语言实现。题目Given a roman numeral, convert it to an inte...
  • xunalove
  • xunalove
  • 2017年08月29日 12:02
  • 334

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

package Linkedin; public class RomeToArabic { public static void main(String[] args) { String s...
  • hellobinfeng
  • hellobinfeng
  • 2013年10月22日 03:24
  • 9068

送给大家一个把阿拉伯数字与罗马数字互换的代码 -.- 仅支持4000以下的转化

阿拉伯数字与罗马数字互换
  • leibniz_zhang
  • leibniz_zhang
  • 2016年06月04日 08:55
  • 1238

leetcode 罗马数字与整数的转换算法

leecode 罗马数字与整数的转换算法
  • net_wolf_007
  • net_wolf_007
  • 2016年06月27日 18:01
  • 3865

罗马数字与阿拉伯数字的相互转化

题目 1 Given an integer, convert it to a roman numeral. Input is guaranteed to be within the range ...
  • cjsh_123456
  • cjsh_123456
  • 2017年10月16日 14:01
  • 151

罗马数字,c#,怎么进行转换!好用

http://topic.csdn.net/u/20081222/15/cd27747f-2b46-4fe6-97dc-2d6889dc4a26.html摘自,感谢原作者,转帖留念1.罗马数字常识以下...
  • NewMap
  • NewMap
  • 2010年06月02日 13:59
  • 3198

python实现阿拉伯数字和罗马数字的互相转换

题目很简单,如果之前也做过这种题目的话,相信对于什么是罗马数字就不会很陌生了,罗马数字是很古老的计数方法,现在的一些地方还有见到它的使用,下面简单贴两张维基百科的图片简单回顾一下罗马数字: ...
  • Together_CZ
  • Together_CZ
  • 2017年08月05日 16:43
  • 1844

Leetcode 13题 罗马数字转换为整形

Given a roman numeral, convert it to an integer.Input is guaranteed to be within the range from 1 to...
  • evolone
  • evolone
  • 2015年04月01日 22:39
  • 1095
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数字转换 转成罗马数字
举报原因:
原因补充:

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