分析:此题虽然类似于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. 【NOIP 2017】逛公园

    Description 策策同学特别喜欢逛公园.公园可以看成一张N个点M条边构成的有向图,且没有 自环和重边.其中1号点是公园的入口,N号点是公园的出口,每条边有一个非负权值, 代表策策经过这条边所要 ...

  2. 【Ural1277】 Cops and Thieves 无向图点连通度问题

    1277. Cops and Thieves Time limit: 1.0 secondMemory limit: 64 MB The Galaxy Police (Galaxpol) found ...

  3. ●BZOJ 4556 [Tjoi2016&Heoi2016]字符串

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=4556 题解: 巨恶心...但是题很好呀,可以练习好几个比较麻烦的算法~ 1).预处理 首先用 ...

  4. VK Cup 2017 - Квалификация 2

    因为资格赛1已经通过了,资格赛2随便打打玩.这次题目比上次还简单,FallDream看了两眼觉得太水就不做了,我一个人闲着无聊只好默默做了 A. Новый пароль 题目大意:给出N和K,要求构 ...

  5. hdu 5491(位运算)

    题意:给你n,a,b. 希望得到比n大,二进制1的个数在 a ,b之间的最小的数 思路:①满足条件,输出 ②num < a 从右找到是0的最小位,变成1 ③num > b从右到左找是1的最 ...

  6. [BZOJ]1014 火星人prefix(JSOI2008)

    一边听省队dalao讲课一边做题真TM刺激. BZOJ的discuss简直就是题面plus.大样例.SuperHINT.dalao题解的结合体. Description 火星人最近研究了一种操作:求一 ...

  7. python安装pip以及导入第三方包

    python有着强大的第三方库,数量很多且功能强大. 最原始的办法是在官网上下载压缩包,解压,然后运行setup.py来进行安装. 显然这种方法很繁琐,不方便.因此有了包管理工具. pip是一个包管理 ...

  8. Linux学习之CentOS(十五)----磁盘管理之 启动挂载(转)

    启动挂载 /etc/fstab 及 /etc/mtab 刚刚上面说了许多,那么可不可以在启动的时候就将我要的文件系统都挂好呢?这样我就不需要每次进入 Linux 系统都还要在挂载一次呀!当然可以啰!那 ...

  9. web性能优化之---JavaScript中的无阻塞加载性能优化方案

    一.js阻塞特性 JS 有个很无语的阻塞特性,就是当浏览器在执行JS 代码时,不能同时做其他任何事情,无论其代码是内嵌的还是外部的. 即<script>每次出现都会让页面等待脚本的解析和执 ...

  10. 【转】动态规划DP

    [数据结构与算法] DP 动态规划 介绍 原创 2017年02月13日 00:42:51 最近在看算法导论. DP全称是dynamic programming,这里programming不是编程,是一 ...