字符型和整型的相互转换

问题遇到的现象和发生背景

字符型和整型的转换

中间的字符型和整型相互转换是怎么实现的啊?

其他进制转十进制中,讲字符型转换成整型:

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 码表,供参考:

img

回答:这代码写得好啊,实现了别的进制的字符串数字转化为十进制数字,也可以将十进制转化为其他进制的字符串形式。
通过底层的运算规则实现,十进制转化为别的进制就是进行除法,然后依次形成左边的高位到右边的低位。而别的进制转化为十进制就是从右往左,从低位开始进行乘法,乘以这一位所在的位置对应的十进制的数。数学思想还是很清晰的