分析:此题虽然类似于atoi函数,但毕竟double为64位, 而且支持小数,因而边界条件更加严格,写代码时需要更加注意。

#include <errno.h>
#include <float.h>
#include <stdio.h>
#include <stdlib.h>
#include "math.h"

enum status {
	invaild = 0, vaild
};
int g_status = vaild;

int isspace(const char* str) {
	return *str == ' ';
}

int isDigit(char num) {
	if (num >= '0' && num <= '9') {
		return 1;
	} else {
		return 0;
	}
}

//对atof函数进行扩充,使其可以处理科学计数法形式的字符如 123.45e-6
double strToDouble(const char* nptr) {

	double val = 0, power = 1;
	int exp = 0;

	if (nptr == NULL) {
		return 0;
	}
	g_status = invaild;
	//跳过空格
	while (*nptr == ' ') {
		nptr++;
	}

	int flag = *nptr == '-' ? -1 : 1;
	if (*nptr == '-' || *nptr == '+') {
		nptr++;
	}

	while (isDigit(*nptr)) {
		val = val * 10 + *(nptr++) - '0';
	}

	if (*nptr == '.') {
		nptr++;
	}

	while (isDigit(*nptr)) {
		val = val * 10 + *(nptr++) - '0';
		power *= 10;
	}

	val = val / power;

	if (*nptr == 'e' || *nptr == 'E') {
		nptr++;
		int eflag = *nptr == '-' ? -1 : 1;
		if (*nptr == '-' || *nptr == '+') {
			nptr++;
		}
		while (isDigit(*nptr)) {
			exp = exp * 10 + *(nptr++) - '0';
		}

		//是否越界
//		 else

		if (eflag == 1) {
			if (val > DBL_MAX * pow(10.0, (double) -exp)) {
				return DBL_MAX;
			}
			while (exp-- > 0) {
				val *= 10;
			}
		} else if (eflag == -1) {
			if (val < DBL_MIN * pow(10.0, (double) exp)) {

				return DBL_MIN;
			}
			while (exp-- > 0) {
				val /= 10;
			}
		}
	}

	if (*nptr == '\0') {
		g_status = vaild;
	}
	return flag * val;

}

int main(void) {
//	DBL_MIN: 2.2250738585072014e-308
//	DBL_MAX: 1.7976931348623157e+308
	setvbuf(stdout, NULL, _IONBF, 0);
	char str[100] = "1.79e308";
	double num;
	num = strToDouble(str);
	if (g_status) {
		printf("%.16e\n", num);
	} else {
		printf("%s", "invaild input!!!");
	}

	return EXIT_SUCCESS;
}

实现string到double的转换的更多相关文章

  1. double型转换成string型

    double型转换成string型 题目描写叙述: 如有一个函数.其可接受一个long double參数,并将參数转换为字符串.结果字符串应保留两位小数,比如,浮点值123.45678应该生成&quo ...

  2. string与double的互相转换

    #include <iostream> #include <string> #include <sstream> string DoubleToString(dou ...

  3. string和double之间的相互转换(C++)

    很多人都写过这个标题的文章,但本文要解决的是确保负数的string和double也可以进行转换. 代码如下: string转double double stringToDouble(string nu ...

  4. 关于==和equals()方法&Java中string与char如何转换&String,StringBuffer

    1.对于基本数据类型,可以直接使用==和!=进行内容比较 如:int x=30;        int y=30;         x==y;  //true 基本数据类型 简单类型(基本类型) bo ...

  5. String转double失去精度问题

    最近遇到一个坑,微信小程序中退款 19.9的字符串转double变成19.89,导致退不成功 . 坑死我了.现在把更改后的代码贴出来 public static void main(String[] ...

  6. 与String有关的强制转换

    String --> int int i = Integer.parseInteger("123"); String --> double double d = Dou ...

  7. go中string和slice no-copy转换

    在go里面,string和slice的互换是需要进行内存拷贝的,虽然在底层,它们都只是用 pointer + len来表示的一段内存. 通常,我们不会在意string和slice的转换带来的内存拷贝性 ...

  8. string 到 wstring的转换

    string 到 wstring的转换_一景_新浪博客     string 到 wstring的转换    (2009-08-10 20:52:34)    转载▼    标签:    杂谈    ...

  9. 利用Gson进行String和对象的转换

    利用Gson进行String和对象的转换 /** * 从JsonStr中解析BUserBase * @param jsonStr * @return */ public static BUserBas ...

随机推荐

  1. [SCOI2016]幸运数字

    题目描述 A 国共有 n 座城市,这些城市由 n-1 条道路相连,使得任意两座城市可以互达,且路径唯一.每座城市都有一个幸运数字,以纪念碑的形式矗立在这座城市的正中心,作为城市的象征. 一些旅行者希望 ...

  2. [JSOI2007]祖码Zuma

    题目描述 这是一个流行在Jsoi的游戏,名称为祖玛. 精致细腻的背景,外加神秘的印加音乐衬托,彷佛置身在古老的国度里面,进行一个神秘的游戏——这就是著名的祖玛游戏.祖玛游戏的主角是一只石青蛙,石青蛙会 ...

  3. bzoj 4545: DQS的trie

    Description DQS的自家阳台上种着一棵颗粒饱满.颜色纯正的trie. DQS的trie非常的奇特,它初始有n0个节点,n0-1条边,每条边上有一个字符.并且,它拥有极强的生长力:某个i时刻 ...

  4. 习题9-4 uva 1630

    题意: 给你一串数字,要求你对其进行折叠使其长度最短. 折叠情况:全是一个字母 & 重复的字符串 AAAAAAAAAABABABCCD    -->   9(A)3(AB)CCD NEE ...

  5. glusterfs 4.0.1 api 分析笔记1

    一般来说,我们写个客户端程序大概的样子是这样的: /* glfs_example.c */ // gcc -o glfs_example glfs_example.c -L /usr/lib64/ - ...

  6. js将当前时间格式化为年-月-日 时:分:秒

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. easyui常见问题

    EasyUi combobox 下拉列表JS添加首/尾选择项 下拉列表获取数据后,再动态添加一项数据项,如:"<option value=''>全部</option> ...

  8. MySQL Innodb如何找出阻塞事务源头SQL

    在MySQL数据库中出现了阻塞问题,如何快速查找定位问题根源?在实验开始前,我们先梳理一下有什么工具或命令查看MySQL的阻塞,另外,我们也要一一对比其优劣,因为有些命令可能在实际环境下可能并不适用. ...

  9. 31. Next Permutation(中等,搞清楚啥是 next permutation)

    Implement next permutation, which rearranges numbers into the lexicographically next greater permuta ...

  10. 设计模式:HelloWorld之策略模式

    一.概述 策略模式 定义了算法族,分别封装起来,让他们可以互相替换,此模式让算法的变化独立于使用算法的客户. 策略模式的三要素: 抽象策略角色: 策略类,通常由一个接口或者抽象类实现. 具体策略角色: ...