atof函数扩充

k&r习题4-2,扩充使可以处理科学计数法形式
#include<ctype.h>

double atof(char s[])
{
	double val, power, e_sum;
	int e_val;
	int i, sign, e_sign;

	for (i = 0; s[i] == ' '; i++);
	sign = (s[i] == '-') ? (-1) : 1;
	if (s[i] == '+' || s[i] == '-')
		i++;
	for (val = 0.0; isdigit(s[i]); i++)
		val = 10.0 * val + (s[i] - '0');
	if (s[i] == '.')
		i++;
	for (power = 1.0; isdigit(s[i]); i++) {
		val = 10.0 * val + (s[i] - '0');
		power *= 10.0;
	}
	if (s[i] == 'e' || s[i] == 'E')
		i++;

	e_sign = (s[i] == '-') ? (-1) : 1;
	e_sum = 1.0;
	if (s[i] == '+' || s[i] == '-')
		i++;
	for (e_val = 0; isdigit(s[i]); i++)
		e_val = 10 * e_val + (s[i] - '0');
	for (i = 0; i < e_val; i++) {
		if (e_sign > 0)
			e_sum *= 10;
		else
			e_sum /= 10;
	}

	return sign * val / power * e_sum;
}



这是自己写的那个,思路比较简单,基本就是前面步骤的复制,只不过判断的内容换了,这样就显得又臭又长。
答案上那个简洁些,没增加新的变量,用了前面的。

转载于:https://my.oschina.net/sukai/blog/313398

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值