鱼C论坛

 找回密码
 立即注册
查看: 745|回复: 8

[已解决]为什么显示的是负数啊,结果完全对不上(欧拉45)

[复制链接]
发表于 2023-9-3 18:47:28 | 显示全部楼层 |阅读模式
10鱼币
/*
注;条件的选择应当采用最合适的,即搜索时用6角数,节约时间
*/
#include<stdio.h>
#include<math.h>

int determine1(long int a)
{
        int m;
        float n;
        m=(1+pow(1+24*a,0.5))/6;
        n=(1+pow(1+24*a,0.5))/6;
        if(float(m)==n)
        {
                return 1;
        }
        return 0;
}

int determine2(long int a)
{
        int m;
        float n;
        m=(1+pow(1+8*a,0.5))/4;
        n=(1+pow(1+8*a,0.5))/4;
        if(float(m)==n)
        {
                return 1;
        }
        return 0;
}
int main(void)
{
        int i=1;
        int temp=1533776805;
        printf("%d\n",temp);
        int m=285;
        long int n;
        while(i)
        {
                m=m+1;
                n=m*(m+1)/2;
                if(m==55385)
                {
                        printf("%d\n",n);//这里为什么求不出来?
                }
                if(determine1(n)&&determine2(n))//结果对不上?
                {
                        i=0;
                        printf("%d\n",m);
                        printf("%ld\n",n);
                }
        }
        printf("在40755之后最小的既是五角数又是六角数的三角数是%ld\n",n);
        return 0;
}
最佳答案
2023-9-3 18:47:29
问题出在浮点数的比较上。在determine1和determine2函数中,你使用了浮点数来计算m和n的值,并通过比较float(m)和n的值来判断它们是否相等。然而,浮点数的精度有限,可能会导致结果不准确。

解决这个问题的方法是,避免使用浮点数进行比较。你可以将m和n的值转换为整数,并直接比较它们的值。修改determine1和determine2函数如下:

  1. int determine1(long int a)
  2. {
  3.     int m;
  4.     m = (int)((1 + pow(1 + 24 * a, 0.5)) / 6);
  5.     if (m * (m * 6 - 1) == a * 2)
  6.     {
  7.         return 1;
  8.     }
  9.     return 0;
  10. }

  11. int determine2(long int a)
  12. {
  13.     int m;
  14.     m = (int)((1 + pow(1 + 8 * a, 0.5)) / 4);
  15.     if (m * (m * 4 - 1) == a * 2)
  16.     {
  17.         return 1;
  18.     }
  19.     return 0;
  20. }
复制代码


通过这样的修改,你将使用整数进行比较,从而避免了浮点数精度的问题。这样应该能够得到正确的结果。

最佳答案

查看完整内容

问题出在浮点数的比较上。在determine1和determine2函数中,你使用了浮点数来计算m和n的值,并通过比较float(m)和n的值来判断它们是否相等。然而,浮点数的精度有限,可能会导致结果不准确。 解决这个问题的方法是,避免使用浮点数进行比较。你可以将m和n的值转换为整数,并直接比较它们的值。修改determine1和determine2函数如下: 通过这样的修改,你将使用整数进行比较,从而避免了浮点数精度的问题。这样应该能够得 ...
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-9-3 18:47:29 | 显示全部楼层    本楼为最佳答案   
问题出在浮点数的比较上。在determine1和determine2函数中,你使用了浮点数来计算m和n的值,并通过比较float(m)和n的值来判断它们是否相等。然而,浮点数的精度有限,可能会导致结果不准确。

解决这个问题的方法是,避免使用浮点数进行比较。你可以将m和n的值转换为整数,并直接比较它们的值。修改determine1和determine2函数如下:

  1. int determine1(long int a)
  2. {
  3.     int m;
  4.     m = (int)((1 + pow(1 + 24 * a, 0.5)) / 6);
  5.     if (m * (m * 6 - 1) == a * 2)
  6.     {
  7.         return 1;
  8.     }
  9.     return 0;
  10. }

  11. int determine2(long int a)
  12. {
  13.     int m;
  14.     m = (int)((1 + pow(1 + 8 * a, 0.5)) / 4);
  15.     if (m * (m * 4 - 1) == a * 2)
  16.     {
  17.         return 1;
  18.     }
  19.     return 0;
  20. }
复制代码


通过这样的修改,你将使用整数进行比较,从而避免了浮点数精度的问题。这样应该能够得到正确的结果。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-9-3 18:47:34 | 显示全部楼层
你好,显示负数的原因可能是在计算中出现了整形数据溢出。在C语言中,int类型的取值范围是有限的,当超过这个范围时就会发生溢出。可以尝试将变量的类型改为long long或者unsigned long long来避免此类问题。

另外,你提到的结果对不上的问题可能是因为程序中的判断条件存在问题。你可以检查一下determine1和determine2函数是否正确判断了五角数和六角数。除此之外,你也可以检查在程序运行过程中输出的变量是否正确,例如temp、m、n等变量的值是否符合预期。

希望能对你有所帮助!
如果问题已经解决,请设置最佳答案
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-9-3 19:06:26 | 显示全部楼层

此内容为ChatGPT回答,如果胡说八道,请不要理会
如果对你有帮助,请设置一个最佳答案!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-9-3 19:30:06 | 显示全部楼层
琅琊王朝 发表于 2023-9-3 19:06
此内容为ChatGPT回答,如果胡说八道,请不要理会
如果对你有帮助,请设置一个最佳答案!

《答案呢》
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-9-3 20:08:12 | 显示全部楼层
琅琊王朝 发表于 2023-9-3 19:06
此内容为ChatGPT回答,如果胡说八道,请不要理会
如果对你有帮助,请设置一个最佳答案!

答案呢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2023-9-3 22:48:39 | 显示全部楼层
T(55385) = P(31977) = H(27693) = 1533776805
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2023-9-3 22:51:05 | 显示全部楼层
陶远航 发表于 2023-9-3 18:47
你好,显示负数的原因可能是在计算中出现了整形数据溢出。在C语言中,int类型的取值范围是有限的,当超过这 ...

谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2023-9-3 22:54:43 | 显示全部楼层
陶远航 发表于 2023-9-3 18:47
你好,显示负数的原因可能是在计算中出现了整形数据溢出。在C语言中,int类型的取值范围是有限的,当超过这 ...

但是我中间的使用了一个int temp变量来表示最后的答案,1533776805也可以显示出来.但中间的n=m*(m+1)/2还是出来个奇怪的数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-28 20:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表