1 int changestr(char* str)
2 {
3 int len = strlen(str);
4 int sum = 0;
5 float carry = 1.0/10;
6 for(int i=0; i<len; i++)
7 {
8 carry *= 10;
9 sum += (str[len-1-i]-'0')*carry;
10 }
11 return sum;
12 }
其中sum為carry為當(dāng)前位之前的值。
str[len-1-i]-'0'是表示將字符的ascii碼減去0的ascii碼,最后出來的數(shù)字就是需要的數(shù)字。
每次*10的話就把當(dāng)前位往前移了。
*改進(jìn)了算法,增加了支持負(fù)數(shù),以及碰到有問題的字符就會(huì)throw exception