Description
从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
Input
Output
Sample Input
FFFF
Sample Output
65535
注意事项:
1.一开始也是没有考虑变量大小,看了一篇别人的,反应过来要用long long型。
#include<stdio.h>
#include<string.h>
int main()
{
int i,j;
long long n=0;
char ch[10];
scanf("%s",&ch);
j=strlen(ch);
for(i=0;i<j;i++)
{
if(ch[i]>='0'&&ch[i]<='9')
{
n=n*16+ch[i]-'0';
}else if(ch[i]>='A'&&ch[i]<='F'){
n=n*16+ch[i]-'A'+10; //A~F相当于10~15,所以还要加上10
}
}
printf("%lld\n",n);
return 0;
}
2.十六进制:表示方式为0x开头(在C语言中以0x或0X开头);
由0-9和A-F组成,英文字母A,B,C,D,E,F分别表示数字10~15。
3.十六进制转十进制的方法:也可以不用pow函数来求。
eg:123=1*16^2+2*16^1+3*16^0
=(1*16+2)*16+3
4.pta上有一道题更详细,有负数的表示方法,题目如下:
(但是在pta上做的时候用int类型可以过)
习题7-8 字符串转换成十进制整数
分数 15
输入一个以#结束的字符串,本题要求滤去所有的非十六进制字符(不分大小写),组成一个新的表示十六进制数字的字符串,然后将其转换为十进制数后输出。如果在第一个十六进制字符之前存在字符“-”,则代表该数是负数。
输入格式:
输入在一行中给出一个以#结束的非空字符串。
输出格式:
在一行中输出转换后的十进制数。题目保证输出在长整型范围内。
输入样例:
+-P-xf4+-1!#
输出样例:
-3905
代码如下:(借鉴知乎上的一篇笔记,觉得这段代码的思路和逻辑性都很好)
#include<stdio.h>
int main()
{
int i=0,j=0,flag=0,n=0;
char ch,a[80];
a[0]='\0';
while((ch=getchar())!='#')
{
if(ch=='-'&&a[0]=='\0')//first '-',所以还要判断a[0]
{
a[i]=ch;
i++;
}
if((ch>='a'&&ch<='f')||(ch>='A'&&ch<='F')||(ch>='0'&&ch<='9'))
{
a[i]=ch;
i++;
flag=1;
}
}
if(a[0]=='-'&&flag==1)printf("-");
j=i;
for(i=0;i<j;i++)
{
if(a[i]>='0'&&a[i]<='9')
{
n=n*16+a[i]-'0';
}else if(a[i]>='A'&&a[i]<='Z')
{
n=n*16+a[i]-'A'+10;
}else if(a[i]>='a'&&a[i]<='z')
{
n=n*16+a[i]-'a'+10;
}
}
printf("%d\n",n);
return 0;
}