#include<stdio.h>
#include<stdlib.h>
long Tolong(char *str)
{
long i,t=0,m;
for(i=0;str[i+1];i++)
{
if(str[i]>='A'&&str[i]<='F')
m=str[i]-'A'+10;
else
if(str[i]>='a'&&str[i]<='f')
m=str[i]-'a'+10;
else
m=str[i]-'0';
t=t*16+m;
}
sprintf(str,"%ld",t);
return t;
}
int main()
{
char str[2000];FILE *fin, *fout;
if(!(fin=fopen("source.txt","r+")))printf("open error!"),exit(0);
if(!(fout=fopen("result.txt","w")))printf("write error!"),exit(0);
while(!feof(fin))
{
fgets(str,50,fin);
Tolong(str);
fputs(str,fout);
fputs("\n",fout);
}
fclose(fin);
fclose(fout);
return 0;
}
//第二种重定向数据流写法
#include<stdio.h>
#include<stdlib.h>
long Tolong(char *str)
{
long i,t=0,m;
for(i=0;str[i];i++)
{
if(str[i]>='A'&&str[i]<='F')
m=str[i]-'A'+10;
else
if(str[i]>='a'&&str[i]<='f')
m=str[i]-'a'+10;
else
m=str[i]-'0';
t=t*16+m;
}
return t;
}
int main()
{
char str[2000];
if(!(freopen("source.txt","r+",stdin)))printf("open error!"),exit(0);
if(!(freopen("result.txt","w",stdout)))printf("write error!"),exit(0);
while(~scanf("%s",str))printf("%ld\n",Tolong(str));
return 0;
}