字符型和整型的转换
中间的字符型和整型相互转换是怎么实现的啊?
其他进制转十进制中,讲字符型转换成整型:
int charToOct(char a[],int m) {
int product=1,sum=0;
int len=strlen(a);
for(int i=len-1; i>=0; i--) {
if(a[i]<='9') {
sum=sum+(a[i]-'0')*product; //字符型转换成整型
} else if(a[i]<='F') {
sum=sum+(a[i]-'A'+10)*product;
} else if(a[i]<='f') {
sum=sum+(a[i]-'a'+10)*product;
}
product=product*m;
}
return sum;
}
十进制转其他进制中将整形转换成字符型:
//b为输入的十进制数,m为进制,a存储
void octToChar(char a[],int m,int b) {
int i=0;
do {
int k=b%m;
if(k<=9) {
a[i++]='0'+k;//整型转换成字符型
} else {
a[i++]='A'+k-10;
}
b=b/m;
} while(b!=0);
a[i]='\n';
}
字符型转换为整型:
字符型数值如 ‘0’ 的ASCII 码值为48,数值0就是其自身,‘1’的ASCII码值为49,当‘1’-‘0’ = 49-48=1,‘0’-‘0’=48-48=0,得到我们想要的数值。十六进制里数值10用 ‘A' 或 'a' 表示 , 当 ’A‘-'A' = 65 - 65 =0,此时应该得到10,所以用 ’A'-'A'+10=10,以此类推当 ‘F' - 'A' + 10 = 70 - 65 + 10 = 15,小写的 ’a‘类似。
数值转换为字符:
与上面的计算方法反推,数值 0 + ’0‘ = 0 + 48 = 48 = ’0‘,1 + ’0’ = 1 + 48 = 49 = ‘1’,当数值为 10 时,‘A’ + 10 - 10 = ‘A' , 'A' + 11 - 10 = 'B', 类推。
ASCII 码表,供参考:
回答:这代码写得好啊,实现了别的进制的字符串数字转化为十进制数字,也可以将十进制转化为其他进制的字符串形式。
通过底层的运算规则实现,十进制转化为别的进制就是进行除法,然后依次形成左边的高位到右边的低位。而别的进制转化为十进制就是从右往左,从低位开始进行乘法,乘以这一位所在的位置对应的十进制的数。数学思想还是很清晰的