马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
请编写一个函数fun,它的功能是:将一个数字字符串转换为一个整数(不得
调用C语言提供的将字符串转换为整数的函数)。例如,若输入字符串"-1234",则
函数把它转换为整数值 -1234。
以上是题目百度有代码但是有一条看不懂望大佬能帮小弟解释解释#include<stdio.h>
#include<string.h>
long StrToInt(char *s) // 将一个字符串转化为整数
{
long number=0;
while(*s!='\0')
{
number=number*10+*s-'0';
s++;
}
return number;
}
int main(int argc,char *args[])
{
char *str="123456789";
int value=0;
value=StrToInt(str);
printf("%ld\n",value);
return 0;
}
其中number=number*10+*s-'0';这条语句说是为了排序为什么要这么写呢?为什么乘10呢?
为什么乘以十~因为你最后要输出十进制整型啊,这是个十进制算法啊。
来看循环~ number =number * 10 + *s - '0'
指针变量 s 存放的是 字符串 str 的地址 这个应该不难理解~ 好~接着看循环!
str 存放的是 “123456789”
我们一步一步来看~
1. number = number * 10 + *s - '0' 等价于 number = 0 * 10 + 49 - 48 == 1
PS : 49 和 48 是对应的ascll值 字符‘1’ 和 字符 ‘0’ 接着看循环
2.number = number * 10 + *s - '0' 等价于 number = 1 * 10 + 50 - 48 == 12
3.number = number * 10 + *s - '0' 等价于 number = 12 * 10 + 51 - 48 == 123
.................
9.number = number * 10 + *s - '0' 等价于 number = 12345678 * 10 + 57 - 48 == 123456789
|