|
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;
}
问题出在浮点数的比较上。在determine1和determine2函数中,你使用了浮点数来计算m和n的值,并通过比较float(m)和n的值来判断它们是否相等。然而,浮点数的精度有限,可能会导致结果不准确。
解决这个问题的方法是,避免使用浮点数进行比较。你可以将m和n的值转换为整数,并直接比较它们的值。修改determine1和determine2函数如下:
- int determine1(long int a)
- {
- int m;
- m = (int)((1 + pow(1 + 24 * a, 0.5)) / 6);
- if (m * (m * 6 - 1) == a * 2)
- {
- return 1;
- }
- return 0;
- }
- int determine2(long int a)
- {
- int m;
- m = (int)((1 + pow(1 + 8 * a, 0.5)) / 4);
- if (m * (m * 4 - 1) == a * 2)
- {
- return 1;
- }
- return 0;
- }
复制代码
通过这样的修改,你将使用整数进行比较,从而避免了浮点数精度的问题。这样应该能够得到正确的结果。
|
最佳答案
查看完整内容
问题出在浮点数的比较上。在determine1和determine2函数中,你使用了浮点数来计算m和n的值,并通过比较float(m)和n的值来判断它们是否相等。然而,浮点数的精度有限,可能会导致结果不准确。
解决这个问题的方法是,避免使用浮点数进行比较。你可以将m和n的值转换为整数,并直接比较它们的值。修改determine1和determine2函数如下:
通过这样的修改,你将使用整数进行比较,从而避免了浮点数精度的问题。这样应该能够得 ...
|