LeetCode-633. 平方数之和

embedded/2025/2/21 2:18:21/

1、题目描述

给定一个非负整数 c ,你要判断是否存在两个整数 a 和 b,使得 a2 + b2 = c 。

示例 1:

输入:c = 5
输出:true
解释:1 * 1 + 2 * 2 = 5

示例 2:

输入:c = 3
输出:false

提示:

  • 0 <= c <= 231 - 1

 2、代码:

class Solution {
public:bool judgeSquareSum(int c) {// 定义两个指针 a 和 b// a 从 0 开始,b 从 sqrt(c) 开始long a = 0; // 使用 long 防止溢出long b = static_cast<long>(sqrt(c)); // b 初始化为 c 的平方根// 双指针法:a 从左向右移动,b 从右向左移动while (a <= b) {// 计算当前 a^2 + b^2 的值auto sum = a * a + b * b;if (sum > c) {// 如果 sum 大于 c,说明 b 的值太大了,需要减小 b--b;} else if (sum < c) {// 如果 sum 小于 c,说明 a 的值太小了,需要增大 a++a;} else {// 如果 sum 等于 c,找到了符合条件的 a 和 b,返回 truereturn true;}}// 如果循环结束仍未找到符合条件的 a 和 b,返回 falsereturn false;}
};

3、解题思路

  1. 数学性质

    • 如果存在两个整数 ab 满足 a^2 + b^2 = c,那么 ab 的平方值一定在 [0, c] 范围内。
    • 因此,我们可以通过枚举一个变量(如 a),并计算另一个变量(如 b)是否满足条件。
  2. 双指针法

    • 使用两个指针 ab,分别从 0sqrt(c) 开始移动。
    • 计算当前的平方和 sum = a^2 + b^2
      • 如果 sum == c,说明找到了符合条件的 ab,返回 true
      • 如果 sum < c,说明需要增大 a(即让 a++)。
      • 如果 sum > c,说明需要减小 b(即让 b--)。
    • a > b 时,结束循环,返回 false
  3. 时间复杂度

    • 由于 ab 分别从两端向中间移动,最多需要遍历 O(sqrt(c)) 次,因此时间复杂度为 O(sqrt(c))

http://www.ppmy.cn/embedded/163954.html

相关文章

账号存活率骤降19%?2025跨境账号安全白皮书预警

账号安全危机来袭&#xff0c;跨境电商如何应对挑战&#xff1f; 在全球电商产业快速扩张的今天&#xff0c;账号安全问题日益严峻&#xff0c;尤其是在跨境电商领域。根据2025年《跨境账号安全白皮书》的报告&#xff0c;跨境电商平台账号存活率骤降19%&#xff0c;这一令人震…

第435场周赛:奇偶频次间的最大差值 Ⅰ、K 次修改后的最大曼哈顿距离、使数组包含目标值倍数的最少增量、奇偶频次间的最大差值 Ⅱ

Q1、奇偶频次间的最大差值 Ⅰ 1、题目描述 给你一个由小写英文字母组成的字符串 s 。请你找出字符串中两个字符的出现频次之间的 最大 差值&#xff0c;这两个字符需要满足&#xff1a; 一个字符在字符串中出现 偶数次 。另一个字符在字符串中出现 奇数次 。 返回 最大 差值…

AI前端开发技能提升与ScriptEcho:拥抱智能时代的新机遇

在AI技术飞速发展的今天&#xff0c;AI写代码工具不再是科幻电影里的场景&#xff0c;而是已经融入到我们的日常开发工作中。AI前端开发作为一门新兴的技术&#xff0c;正快速改变着我们的工作方式。然而&#xff0c;想要在这个领域立足并脱颖而出&#xff0c;就必须不断提升自…

提升顾客转化率:融合2+1链动模式AI智能名片与S2B2C商城小程序的创新策略

摘要&#xff1a;在数字化转型的背景下&#xff0c;零售商面临着提升顾客转化率的巨大挑战。本文旨在探讨如何通过整合顾客行为数据、21链动模式、AI智能名片及S2B2C商城小程序等新兴技术与商业模式&#xff0c;来精准定位顾客需求&#xff0c;优化营销策略&#xff0c;从而提高…

前端自动化部署的极简方案

写在前面 在现代软件开发中&#xff0c;自动化部署已经成为了一个不可或缺的环节。它可以大幅度提高开发效率&#xff0c;减少人为错误&#xff0c;并且使得整个部署过程更加可靠和可控。对于前端项目来说&#xff0c;自动化部署同样重要。本文将介绍一个极简的前端自动化部署…

Deep seek学习日记1

Deepseek最强大的就是它的深度思考&#xff0c;并且展现了它的思考过程。 五种可使用Deep seek的方式&#xff08;应该不限于这五种&#xff0c;后续嵌入deepseek的应该更多&#xff0c;多了解一点因为官网容易崩~~&#xff09;&#xff1a; 1.deep seek官网 2.硅基流动silicon…

【Rust中级教程】1.12. 生命周期(进阶) Pt.2:生命周期变型、协变、不变、逆变

喜欢的话别忘了点赞、收藏加关注哦&#xff08;加关注即可阅读全文&#xff09;&#xff0c;对接下来的教程有兴趣的可以关注专栏。谢谢喵&#xff01;(&#xff65;ω&#xff65;) 这篇文章在Rust初级教程的基础上对生命周期这一概念进行了补充&#xff0c;建议先看【Rust自…

Leetcode 224-基本计算器

先做Leetcode 227再做本题 本题在227的基础上多了括号 题解 关于括号的递归调用思想请参考labuladong 将 减法、乘法、除法 转换为 加法 某个数 num, 如果前面的对应的运算符是 -&#xff0c;那么 将 -num 压入栈中 这样&#xff0c;我们只需在最后将栈的元素全部弹出&#x…