一、数字转换为字符串
1.1 解题思路
不使用库函数实现数字转换为字符串,此时必须借助ASCII码进行转换,我们知道字符‘0’与数字0直接ASCII码值相差48,要将对应数字转换为字符,只需加上字符‘0’即可,但是此时我们是要将一串数字转换为一个字符串,因此我们就需要借助一个数组来储存转换好的对应数组,之后输出即可。
注:因为在转换数字时是从最低位开始转换的,因此存入数组中的字符顺序是颠倒的,因此在输出字符串时应该倒序输出。
1.2 代码实现
//将数字转换为对应字符串
#include <stdio.h>
void number_to_string(int n, char s[100])
{
int i = 0;
int p = n;//保存n,是为了之后输出整数n
while (n>0)
{
s[i++] = n % 10 + '0';
//举个例子:输入为1234
//n = 1234 s[0] = 1234%10 +'0' = 4(此时为字符4),n = n/10 = 123
//n = 123 s[1] = 123%10+'0' = 3 n = n/10 = 12;
n = n / 10;
}
s[i] = '\0';
printf("整数是:%d\n", p);
printf("字符串是:");
int m;//此时应该倒序输出此字符串
for (m = i - 1; m >= 0; m--)
{
printf("%c ", s[m]);
}
printf("\n");
}
int main()
{
int n;
char s[100] = { 0 };
printf("请输入要转化的数字\n");
scanf("%d", &n);
number_to_string(n, s);
return 0;
}
二、字符串转换为数字
2.1 解题思路
不使用库函数实现字符串转换为数字,同样得借助ASCII码,一个字符减去字符‘0’即转换为对应的数字,仔细观察我们其实不难发现,让n初始值为0,通过表达式n = n*10+(*str - ‘0’),可以转换为对应位的数字。
2.2 代码实现
#include <stdio.h>
#include <assert.h>
int string_to_number(char *str)
{
int n = 0;
assert(str);
while (*str != '\0')
{
while (*str >= '0' && *str <= '9')//判断字符串是否全为数字
{
n = n * 10 + (*str - '0');
//当n = 0时,*str = 1,n = 0*10 + ('1' - '0') = 1;
//n = 1,*str = 2,n = 1*10+('2' - '0') = 12;
//n = 12,*str = 3,n = 12*10+('3' - '0') = 123;
//n = 123,*str = 4 n = 123*10+('4' - '0') = 1234;
str++;
}
return n;
}
return 0;
}
int main()
{
char a[] = "12345";
printf("%d\n", string_to_number(a));
return 0;
}