求一个高效的double转char*的算法,C或C++

形如
double 33.333 => char* "33.333"
double 1e+5 => char* "100000"

要求:

  1. 考虑浮点数范围(不能直接强转为int或long)

  2. 考虑浮点数的精度(处理边界问题)

  3. 尽量不使用其它库函数

阅读 11.1k
3 个回答

sprintf难道不够高效?
不用库函数把sprintf关于%f的拿出来就好了。

如果你想连sprintf对%的处理都省掉的话,建议使用_gcvt_s函数。

使用方法如下:

    char buffer[320];
    _gcvt_s(buffer, 320, number, 30);
    vint len = (vint)strlen(buffer);
    if (buffer[len - 1] == '.')
    {
        buffer[len - 1] = '\0';
    }

如果你使用的编译期没有_gcvt_s的话,可以自己封装一个:

void _gcvt_s(char* buffer, size_t size, double value, vint numberOfDigits)
{
    sprintf(buffer, "%f", value);
    char* point = strchr(buffer, '.');
    if(!point) return;
    char* zero = buffer + strlen(buffer);
    while(zero[-1] == '0')
    {
        *--zero = '\0';
    }
    if(zero[-1] == '.') *--zero = '\0';
}

这样程序在别的编译期下既,而且在VC++下面又可以发挥优异的性能。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题