Chinaunix首页 | 论坛 | 博客
  • 博客访问: 66710
  • 博文数量: 17
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 154
  • 用 户 组: 普通用户
  • 注册时间: 2014-05-12 22:56
个人简介

不卑不亢

文章分类

全部博文(17)

文章存档

2016年(1)

2015年(13)

2014年(3)

分类: C/C++

2015-03-21 14:26:44


点击(此处)折叠或打开

  1. #include <stdio.h>
  2. #include <ctype.h>

  3. /* atof: convert string s to double */
  4. double atof(char *s)
  5. {
  6.     double val, power;
  7.     int i, sign, exp;

  8.     for (i = 0; isspace(s[i]); i++);        /* skip white space */

  9.     sign = (s[i] == '-')? -1 : 1;
  10.     if (s[i] == '+' || s[i] == '-')
  11.         i++;
  12.     for (val = 0.0; isdigit(s[i]); i++)
  13.         val = 10.0 * val + (s[i] - '0');
  14.     if (s[i] == '.')
  15.         i++;
  16.     for (power = 1.0; isdigit(s[i]); i++) {
  17.         val = 10.0 * val + (s[i] - '0');
  18.         power *= 10.0;
  19.     }
  20.     val = sign * val / power;
  21.     if (s[i] == 'e' || s[i] == 'E') {
  22.         sign = (s[++i] == '-')? -1 : 1;
  23.         if (s[i] == '-' || s[i] == '+')
  24.             i++;
  25.         for (exp = 0; isdigit(s[i]); i++)
  26.             exp = 10 * exp + (s[i] - '0');
  27.         if (sign == 1) {
  28.             while (exp-- > 0)
  29.                 val *= 10;        /* positive exponent */
  30.         } else {
  31.             while (exp-- > 0)
  32.                 val /= 10;        /* negative exponent */
  33.         }
  34.     }

  35.     return val;
  36. }

  37. int main()
  38. {
  39.     char x[] = "-123.45e-6";
  40.     double val;

  41.     val = atof(x);

  42.     printf("%g\n", val);

  43.     return 0;
  44. }

阅读(1758) | 评论(0) | 转发(0) |
0

上一篇:链式栈

下一篇:atoi的实现

给主人留下些什么吧!~~