c语言罗马数字转十进制,OJ刷题---罗马数字转十进制

题目要求:

1f98f0b95f3d010a82842e4f535f5866.png

751cb7fdd0caf4dc37d68523d521df6c.png

30be7efb6b401a78ee3f1861fad72a2d.png

1010420ded8d824ffb9a1ba18cf9b658.png

输入代码:

#include

using namespace std;

int main()

{

int i,j,n,k;

int num[7]= {1, 5,10,50,100,500,1000}; //罗马数字转换模板

char str[7]= {'I','V','X','L','C','D','M'};

int a[7];//定义一个转换成十进制的保存数组

char pL[7];//要输入的罗马数字

cin>>n;

for(i=0; i

{

int sum=0;

for(j=0; j<7; j++)

{

a[j]=-1;

}

cin>>pL; //输入一个罗马数字

for(j=0; pL[j]!='\0'; j++)//将罗马数字转化为详细数值

{

for(k=0; k<7; k++)

{

if(pL[j]==str[k])

{

a[j]=num[k];

break;

}

}

}

for(j=0; j<7; j++)//求终于结果

{

if(a[j]==-1)

break;

if(a[j]

{

sum+=a[j+1]-a[j];

j++;

continue;

}

else

sum+=a[j];

}

cout<

}

return 0;

}

执行结果:

5bc1bdc54018a1eb797da0562d2533f6.png

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值