C语言经典例题

一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?

#include<stdio.h>
int main()
{
int i,j,m,n,x;
for(i=1;i<168/2-1;i++)
{
if(168%i==0)
{
j=168/i;
if((i>j)&&((i+j)%2==0)&&((i-j)/2==0)
{
m=(i+j)/2;
n=(i-j)/2;
x=n*n-100;
printf("%d+100=%d*%d);
printf("%d+268=%d*%d);
}
}
}
return 0;
}

分析下整体的算法:
设 x ; x +100= m*m;
x+100+168=n*n;
(m*m)-(n*n)=168;
(m+n)(m-n)=168;

设 m+n=i;
m-n=j;
i*j=168;
m=168/(i+j); 至少一个为偶数;
n=168/(i-j);由此可得 i 与j 都为偶数或者奇数;
i与 j 都为大于等于2的偶数;
i*j =168;
j>=2 ;
1<i<168/2+1;



int i,j,m,n,x;
for(i=1;1<i<168/2+1)
{
if(168%i==0)
{
j=168/i;
if(i>j)&&((i+j)/2)==0&&((i-j)/2)&&((i-j)%2==0)
{
m=(i+j)/2;
n=(i-j)/2;
x=m*m-100;
printf("%d+100=%d*%d\n",x,m,m);
printf("%d+268=%d*%d\n",x,n,n);








评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值