• double型转换成string型


    double型转换成string型

    题目描写叙述:
    如有一个函数。其可接受一个long double參数,并将參数转换为字符串。结果字符串应保留两位小数,比如,浮点值123.45678应该生成“123.45”这种字符串。表面上看来 这是一个意义不大的编程问题,然而。假设真要在实际中派上用场。函数应设计为具有一定弹性,以同意调用者指定小数位数。另外,函数也应该可以处理各种异常 情况,如像123.0或123这种整数。
    转换函数接口:string do_fraction(long double value, int decplaces = 3)
    题目分析:
    经验之谈:①不管何时须要格式化一个数值。都应该先转换为一个字符串,这样可保证每位数刚好占领一个字符。②须要转化为字符串时候,能够考虑使用库函数
    使用库函数将long double值转化为一个string应该非常easy,可是须要注意以下几个问题:
    1)精度问题
    由于stringstream对象默认精度为6。(这里须要强调一个精度,老式指的是小数位数,新式应该指的是所有位数),这就会有出现一个问题:假设很大的数,比如123456789.9,它就会转化为科学计数法,这显然不是我们须要的,所以我们使用库函数和转换之前,必须先把默认的精度设为最大
    2)小数点位置问题
    定位小数位使用string::find
    在STL算法中使用一个常量来代表“数值未找到”,字符串中是string::npos
    由于我们设定了小数点最大位数decplacea。所以我们要检查小数点位数。假设小于它。那么直接返回字符串。否则小数部分多余的要被截去。

    截断字符串的方法:通常使用
    插入变量之后,怎样截去后面的字符。一般採用自交换
    <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
    參考代码:

    string do_fraction(long double value, int decplaces = 3)
    {
        ostringstream out;
        int prec = numeric_limits::digits10; //18 注意须要加上头文件#include<limits>
        out.precision(prec); //覆盖默认精度
    
        //从流中取出字符串
        string str = out.str();
    
        //推断是否有小数点。且还有decpalces位
        size_t n = str.find(DECIMAL_POINT);
        if((n != string::npos) && (str.size() > n + decplaces)) 
        {
            str[n + decplaces] = ''; //覆盖第一个多余的数字
        }
        str.swap(string(str.c_str())); //删除NULL之后多余的字符
        return str;
    }
    

  • 相关阅读:
    java 事件监听机制组成
    关于父进程和子进程的关系(UAC 绕过思路)
    Fort.js – 时尚、现代的进度提示效果
    Hive学习之函数DDL和Show、Describe语句
    js完美的div拖拽实例代码
    SSH2框架实现注冊发短信验证码实例
    再看C#中的托付和事件
    RGB(FFFFFF)转255:255:255
    单一目的聚集操作
    智慧城市,在中国的北海边再画一个圈——大连“中国首届智慧城市协同创新峰会”请你带好笔
  • 原文地址:https://www.cnblogs.com/yutingliuyl/p/7131588.html
Copyright © 2020-2023  润新知