welcome here

这里是小马哥的随文杂记,希望大家多多指点。

蓝桥杯 c++ 罗马数字转换问题

#include"iostream.h"
#include"string.h"
int jisuan(int i,int j,int z)
{ int count=0;
 int a[7]={1,5,10,50,100,500,1000};
 if(z==1) count=a[i];
 if(z==0) count=-a[i];
 return count;
}
int quan(char a,char b)
{ int q,h,p;
char c[7]={'I','V','X','L','C','D','M'};
 for(int i=0;i<7;i++)
 { if(c[i]==a) q=i;
  if(c[i]==b) h=i;
 }
 if(q-h>=0)p=jisuan(q,h,1);
    else p=jisuan(q,h,0);
 return p;
}

int f(char b[],int n)
{ int count=0;
 for(int i=0;i<n;i++)
 { count=count+quan(b[i],b[i+1]);
 }
 return count;
}
main()
{ char a[100][20];
 int n;
 cout<<"********¥¥¥¥¥¥¥罗马字符转化为阿拉伯数字值¥¥¥¥¥¥¥*****"<<endl;
 cout<<"insert:";
 cin>>n;
 for(int i=0;i<n;i++)
  cin>>a[i];
 for(int j=0;j<n;j++)
  cout<<f(a[j],strlen(a[j]))<<endl;
}

阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011017652/article/details/17083801
文章标签: 数字转换
个人分类: 计算机 蓝桥杯
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

不良信息举报

蓝桥杯 c++ 罗马数字转换问题

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭