蓝桥杯 完全平方数 刷题笔记

关键分析


**完全平方数的质因数指数特性**

**核心结论**:

一个数是完全平方数,当且仅当它的所有质因数的指数均为偶数。


cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
#define int long long
int n;

signed main(){
    cin >> n;
    int res = 1;
    for(int i = 2; i*i <= n; i++){  // 枚举质因子,从小的开始
        if(n % i == 0){
            int s = 0;
            while(n % i == 0) s++, n /= i;  // 计算质因子i的次数s
            if(s % 2) res *= i;  // 如果次数是奇数,乘到结果中
        }
    }
    if(n > 1) res *= n;  // 处理剩余的大质因子
    cout << res << endl;
    return 0;
}

**n = 199994535 的质因数分解过程**


**步骤1:初始化**

  • **目标**:将 `n = 199994535` 分解为质因数的乘积形式。

  • **初始值**:`n = 199994535`


**步骤2:试除小质数**

  1. **判断是否能被2整除**:
  • `199994535` 是奇数,无法被2整除。
  1. **判断是否能被5整除**:
  • **末位是5**,可以直接整除。

  • **计算**:`199994535 ÷ 5 = 39998907`。

  • **记录质因数**:`5^1`。

  • **更新n**:`n = 39998907`。

  1. **继续判断是否能被5整除**:
  • `39998907` 末位是7,无法被5整除。
  1. **判断是否能被3整除**:
  • **各位和**:`3+9+9+9+8+9+0+7 = 54`,能被3整除。

  • **计算**:`39998907 ÷ 3 = 13332969`,次数 `s=1`。

  • **继续除以3**:`13332969 ÷ 3 = 4444323`,次数 `s=2`。

  • **继续除以3**:`4444323 ÷ 3 = 1481441`,次数 `s=3`。

  • **继续除以3**:`1481441 ÷ 3 = 493813.666...`(无法整除)。

  • **记录质因数**:`3^3`。

  • **更新n**:`n = 1481441`。


**步骤3:处理剩余的大质数**

  • **当前n**:`1481441`。

  • **试除到平方根**:`√1481441 ≈ 1217`。

  • **尝试质数3到1217**:

  • **3**:已处理过。

  • **5**:末位非0/5。

  • **7**:`1481441 ÷ 7 ≈ 211634.428`(余数非0)。

  • **11**:交替和法验证,无法整除。

  • **13**:`1481441 ÷ 13 ≈ 113957`(余数非0)。

  • ...(继续试除所有质数到1217)。

  • **结论**:未找到其他质因数。

  • **记录质因数**:`1481441^1`。


**最终质因数分解**

199994535 = 5\^1 \\times 3\^3 \\times 1481441\^1


**步骤4:计算最小x**

  • **目标**:使所有质因数的指数为偶数。

  • **分析**:

  • `5` 的指数为 `1`(奇数),需乘一次 `5`。

  • `3` 的指数为 `3`(奇数),需乘一次 `3`。

  • `1481441` 的指数为 `1`(奇数),需乘一次 `1481441`。

  • **结果**:

x = 5 *3 * 1481441 = 22221615


**最终答案**

  • **最小x**:`22221615`

  • **验证**:`199994535 × 22221615` 是完全平方数。

相关推荐
电子_咸鱼2 小时前
LeetCode——Hot 100【电话号码的字母组合】
数据结构·算法·leetcode·链表·职场和发展·贪心算法·深度优先
递归不收敛4 小时前
大语言模型(LLM)入门笔记:嵌入向量与位置信息
人工智能·笔记·语言模型
冷雨夜中漫步4 小时前
高级系统架构师笔记——数据库设计基础知识(5)Armstrong公理系统、无损连接和有损连接
笔记·系统架构
微笑尅乐4 小时前
中点为根——力扣108.讲有序数组转换为二叉搜索树
算法·leetcode·职场和发展
im_AMBER5 小时前
算法笔记 05
笔记·算法·哈希算法
夏鹏今天学习了吗5 小时前
【LeetCode热题100(46/100)】从前序与中序遍历序列构造二叉树
算法·leetcode·职场和发展
吃着火锅x唱着歌5 小时前
LeetCode 2389.和有限的最长子序列
算法·leetcode·职场和发展
007php0076 小时前
百度面试题解析:微服务架构、Dubbo、Redis及其一致性问题(一)
redis·百度·docker·微服务·容器·职场和发展·架构
Element_南笙6 小时前
吴恩达新课程:Agentic AI(笔记2)
数据库·人工智能·笔记·python·深度学习·ui·自然语言处理
koo3647 小时前
李宏毅机器学习笔记21-26周汇总
人工智能·笔记·机器学习