C语言经典100题---例003--- 完全平方数

目录

题目:

题目分析

C语言实现

输出结果


题目:

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

题目分析

(1) x + 100 = m^2,这里取m>=0

(2) x + 100 + 168 = n^2 即 x + 268 = n^2,这里取n>=0

将(2)减去(1)得到:(n^2 - m^2) = 168

(3) 即 (n-m)(n+m) = 168

设a = n - m, b = n + m,则n+m>0,由(3)知 (n-m)*正数 = 168,所以n-m也是正数

即,n>m.所以有b>a>0.

由于n和m都是整数,所以a和b同奇偶(因为n和m都是整数,那么n+m和n-m同奇偶)

又因为a*b = 168(偶数)。所以a和b都是偶数。

综上:

  • a < b
  • a * b = 168
  • a和b都是偶数
  • 由a和b可以解出n和m: n = (a+b)/2, m = (b-a)/2,且n和m都是正整数(由于a和b都是偶数,所以n和m都是整数)
  • 然后由m或n得到x: x = m^2 - 100
  • 最后验算 x + 100 + 168 = n^2

C语言实现

cpp 复制代码
#include <stdio.h>
#include <math.h>
int main() {

    int a, b, x, m, n;

    printf("---------------------------------------\n");

    // a < b;a * b = 168 所以 a <= sqrt(168)
    for (a = 2; a <= sqrt(168);) 
    {
        b = 168 / a;

        if (a < b && (b % 2 == 0) && (a % 2 == 0))
        {
            n = (a + b) / 2;
            m = (b - a) / 2;
            x = m * m - 100;        // 求出x

            // 再到另一个式子中验算
            if (x+100+168 == n * n)
            {
                printf("%d + 100 = %d ^ 2\n", x, m);
                printf("%d + 100 + 168 = %d ^ 2\n", x, n);
                printf("---------------------------------------\n");
            }
        }
        // a是偶数 所以每次可以+2
        a += 2;
    }
}

输出结果

cpp 复制代码
---------------------------------------
1581 + 100 = 41 ^ 2
1581 + 100 + 168 = 43 ^ 2
---------------------------------------
261 + 100 = 19 ^ 2
261 + 100 + 168 = 23 ^ 2
---------------------------------------
21 + 100 = 11 ^ 2
21 + 100 + 168 = 17 ^ 2
---------------------------------------
-99 + 100 = 1 ^ 2
-99 + 100 + 168 = 13 ^ 2
---------------------------------------
相关推荐
weixin_421725262 小时前
C语言常用字符串函数:长度、比较、拼接和查找
c语言·字符串函数·查找·比较·长度
yzq1991272 小时前
C语言#和##的用法(附带示例)
c语言·宏定义·预处理运算符·字符串化·标记连接
无敌昊哥战神4 小时前
【LeetCode 37】解数独 (Sudoku Solver) —— 回溯法详解 (Python/C/C++)
c语言·c++·python·算法·leetcode
jinyishu_5 小时前
链表经典OJ题
c语言·数据结构·算法·链表
爱编码的小八嘎5 小时前
C语言完美演绎9-14
c语言
li1670902706 小时前
第二十五章:C++11(下)
c语言·开发语言·数据结构·c++
代码中介商17 小时前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法
爱编码的小八嘎19 小时前
C语言完美演绎9-12
c语言
Navigator_Z21 小时前
LeetCode //C - 1031. Maximum Sum of Two Non-Overlapping Subarrays
c语言·算法·leetcode
leoufung1 天前
LeetCode 30:Substring with Concatenation of All Words 题解(含 C 语言 uthash 实现)
c语言·leetcode·c#