c++ 除法 mark

前一天调试一个算法,被一个小bug折腾了半天,贴出来游行示众:

#include <iostream>
#include <cmath>

int main()
{
       const double pi = 3.141592653589793238;  // double 有效位数为 16
       double d1 = 2.1212;
       double d2 = -5.1515;
       double d3 = 9.1919;

       int k1 = d1/(2*pi);
       int k2 = d2/(2*pi);
       int k3 = d3/(2*pi);

       double t1 = std::fmod(d3, pi);  // (-pi, pi)
       double t2 = std::remainder(d3, 2*pi);  // (-pi,pi)

       // 千万别在算法中将系数写成整数, 改成 1.0/2*d3 或者 1*d3/2 就ok了
       double t3 = 1/2*d3;  // 根据先后顺序得出 t3=0 !!!

       std::cerr << "k_1: " << k1 << std::endl;
       std::cerr << "k_2: " << k2 << std::endl;
       std::cerr << "k_3: " << k3 << std::endl;
       std::cerr << "t_1: " << t1 << std::endl;
       std::cerr << "t_2: " << t2 << std::endl;
       std::cerr << "t_3: " << t3 << std::endl;
}

Output:

k_1: 0
k_2: 0
k_3: 1
t_1: 2.90871
t_2: 2.90871
t_3: 0
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值