C++对任意数字保留任意位有效数字

C++对任意数字保留任意位有效数字,第1张

//第一个参数为原始数据,第二个参数为需要保留的小数数字位数
double round(double d, int n) {
    double t1;
    t1 = d - (int)d;//取小数部分
    t1 *= pow(10, n);//小数点平移
    //原小数部分四舍五入
    if (t1 - (int)t1 >= 0.5) {
        t1 += 1;
        biaoJi = 1;//表示进位     
    }
    t1 = (int)t1; //取整数部分
    t1 /= pow(10, n);//小数点与之前平移方向相反平移
    t1 += (int)d;//加上原本的整数部分
    return t1;//输出结果
}

//第一个参数为原始数据,第二个参数为需要保留的有效数字位数
double foo(double d, int n)
{
    if (d == 0.0) return 0;
    if (fabs(d) > 1)
        //获得保留有效数字小数点需要移动的位数及方向
        n = n - (int)log10(fabs(d)) - 1;
    else
        n = n + (int)log10(1.0 / fabs(d));
    //小数点左移的直接解决
    if (n < 0)
    {
        d = (round)(d / pow(10, 0 - n)) * pow(10, 0 - n);
        n = 0;
    }
    return round(d, n);
}

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/1325516.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-12
下一篇2022-06-12

发表评论

登录后才能评论

评论列表(0条)

    保存