罗马数字转整数
最近在刷力扣,以后,会分享很多编程刷题的答案,然后会整理一些心得,经验和收获分享给大家。
题目描述如下:
以下是通过率百分之百的代码:
int romanToInt(char * s){
char *ch =s;
int sum=0;
int i=0;
while(ch[i]!='\0'){
if(ch[i]=='I'){
if(ch[i+1]!='\0'&&ch[i+1]=='V'){
sum=sum+4;
i=i+1;
}
else if(ch[i+1]!='\0'&&ch[i+1]=='X'){
sum=sum+9;
i=i+1;
}
else{sum=sum+1;}
}
else if(ch[i]=='X'){
if(ch[i+1]!='\0'&&ch[i+1]=='L'){
sum=sum+40;
i=i+1;
}
else if(ch[i+1]!='\0'&&ch[i+1]=='C'){
sum=sum+90;
i=i+1;
}
else{sum=sum+10;}
}
else if(ch[i]=='C'){
if(ch[i+1]!='\0'&&ch[i+1]=='D'){
sum=sum+400;
i=i+1;
}
else if(ch[i+1]!='\0'&&ch[i+1]=='M'){
sum=sum+900;
i=i+1;
}
else{sum=sum+100;}
}
else if(ch[i]=='V'){
sum=sum+5;
}
else if(ch[i]=='L'){
sum=sum+50;
}
else if(ch[i]=='D'){
sum=sum+500;
}
else if(ch[i]=='M'){
sum=sum+1000;
}
// sum=sum+1;
i=i+1;
}
return sum;
}