如果你又更好的解法或问题,欢迎在评论区留言
#include <stdio.h>
int main (void)
{
// 遍历可能的因数i,i的范围是1到84(168/2)
for ( int i = 1; i < 168 / 2 + 1; i++)
{
// 检查i是否为168的因数
if (168 % i == 0)
{
// 计算对应的因数j = 168/i
int j = 168 / i;
// 约束条件:
// 1. 保证m > n (通过i > j实现,因为i = m + n, j = m - n)
// 2. (i + j)必须是偶数,使得m = (i + j)/2为整数
// 3. (i - j)必须是偶数,使得n = (i - j)/2为整数
if (i > j && (i + j) % 2 == 0 && (i - j) % 2 == 0)
{
// 根据因数分解公式计算m和n
// 其中:
// m = (i + j)/2 = ( (m+n) + (m-n) )/2 = m
// n = (i - j)/2 = ( (m+n) - (m-n) )/2 = n
int m = (i + j) / 2;
int n = (i - j) / 2;
// 根据题目公式计算x的值
// x + 100 = n² → x = n² - 100
int x = n * n - 100;
// 输出结果(格式化显示数学关系)
printf ("%d + 100 = %d * %d\n", x, n, n); // 显示x+100=n²
printf ("%d + 268 = %d * %d\n", x, m, m); // 显示x+268=m²
}
}
}
return 0;
}