851463351 发表于 2020-7-18 21:59:09

永恒的蓝色梦想 发表于 2020-7-18 22:00:10

浮点数问题。

851463351 发表于 2020-7-18 22:04:03

永恒的蓝色梦想 发表于 2020-7-18 22:08:05

851463351 发表于 2020-7-18 22:04
那有什么修正的措施吗(吃手手)

#include<stdio.h>
#include<math.h>


int main()
{
    unsigned long long num = 0;
    unsigned long long int weight;

    for(int i = 0; i < 64; i++)
    {
      num += 1ull << i;
    }

    weight = num / 25000;
    printf("%llu\n%llu\n", num, weight);
    return 0;
}

851463351 发表于 2020-7-18 22:11:13

永恒的蓝色梦想 发表于 2020-7-18 22:11:26

851463351 发表于 2020-7-18 22:04
那有什么修正的措施吗(吃手手)

建议以后求 2 的 n 次幂用这个宏(n 必须为非负整数):#define pow2(n) ((1ull)<<(n))

851463351 发表于 2020-7-18 22:12:44

sunrise085 发表于 2020-7-18 22:21:47

pow()函数结果是浮点数,进行运算的时候会出现精度问题,当运算的值达到一定程度就会出现偏差。
这里,当i=53的时候,num的结果就有偏差了,比正常的值大1,从这里开始,就出错了。当i=63的时候,结果刚好溢出,变成了0。
#include<stdio.h>
#include<math.h>
int main()
{
    unsigned long long num = 0;
    unsigned long long weight;
    unsigned long long temp = 1;
    for(int i = 0; i < 64; i++)
    {
      num = num + temp;
      temp=temp*2;
      printf("%d\t%llu\n",i, num);//这一行是让你看看 num 的值,你的那种写法,当i=53的时候就出错了,num比正常值大1,这就导致最终i=63的时候,溢出了。
    }
    weight = num / 25000;
    printf("%llu\n%llu\n", num, weight);
    return 0;
}

851463351 发表于 2020-7-19 09:30:08

页: [1]
查看完整版本: 不懂就问 S1E6 第一题