实验7-3-6 字符串转换成十进制整数(C语言)
题目描述
输入一个以#结束的字符串,本题要求滤去所有的非十六进制字符(不分大小写),组成一个新的表示十六进制数字的字符串,然后将其转换为十进制数后输出。如果在第一个十六进制字符之前存在字符“-”,则代表该数是负数。
输入
输入在一行中给出一个以#结束的非空字符串。
输出
在一行中输出转换后的十进制数。题目保证输出在长整型范围内。
样例输入
+-P-xf4+-1!#
样例输出
-3905
代码
#include<stdio.h>
#include<string.h>
#include<math.h>
int main()
{
int i,j=0,last=0,count;
char c1[10000],a='0',b='0';
for(i=0,j=0;;i++)
{
scanf("%c",&c1[i]);
if(c1[i]=='#')
{
break;
}
else if(c1[i]=='+'||c1[i]=='-')
{
a=c1[i];
}
else if((c1[i]>='0'&&c1[i]<='9'||c1[i]>='A'&&c1[i]<='F'||c1[i]>='a'&&c1[i]<='f')&&a!='0')
{
j++;
if(j==1)
{
b=a;
}
}
}
for(i=0,count=0;i<strlen(c1);i++)
{
if(c1[i]>='0'&&c1[i]<='9'||c1[i]>='A'&&c1[i]<='F'||c1[i]>='a'&&c1[i]<='f')
{
count++;
}
}
for(i=0,j=count-1;i<strlen(c1),j>=0;i++)
{
if(c1[i]>='0'&&c1[i]<='9')
{
last=last+(c1[i]-48)*pow(16,j);
j=j-1;
}
else if(c1[i]>='A'&&c1[i]<='F')
{
last=last+(c1[i]-55)*pow(16,j);
j=j-1;
}
else if(c1[i]>='a'&&c1[i]<='f')
{
last=last+(c1[i]-87)*pow(16,j);
j=j-1;
}
}
if(b=='+'||b=='0')
{
printf("%d\n",last);
}
else if(b=='-')
{
printf("%c%d\n",b,last);
}
return 0;
}