day47—双指针-平方数之和(LeetCode-633)

题目描述

给定一个非负整数 c ,你要判断是否存在两个整数 ab,使得 a^2 + b^2 = c

示例 1:

复制代码
输入:c = 5
输出:true
解释:1 * 1 + 2 * 2 = 5

示例 2:

复制代码
输入:c = 3
输出:false

提示:

  • 0 <= c <= 2^31 - 1

解决方案:

1、数据大小范围:long long,(int 的极限是2^32 -1)

2、平方数就先取该数的算术平方根,分别讨论边界条件

3、算术平方根即是边界极值,另一值从0或1 开始,根据符合条件的大小比较,去压缩中间区域:即极值的左移或右移。

函数源码:

cpp 复制代码
class Solution {
public:
    bool judgeSquareSum(int c) {
        
        long long a=1;
        long long b=sqrt(c);
        double x=sqrt(c);
        
        if(x==b)     return true;

        while(true){
            if(a>b) return false;

            if(a*a+b*b==c)       break;
            else if(a*a+b*b>c)   b--;
            else                 a++;

        }
        
        return true;

    }
};
相关推荐
alphaTao6 小时前
LeetCode 每日一题 2026/2/2-2026/2/8
算法·leetcode
甄心爱学习6 小时前
【leetcode】判断平衡二叉树
python·算法·leetcode
颜酱6 小时前
从二叉树到衍生结构:5种高频树结构原理+解析
javascript·后端·算法
不知名XL6 小时前
day50 单调栈
数据结构·算法·leetcode
@––––––6 小时前
力扣hot100—系列2-多维动态规划
算法·leetcode·动态规划
xsyaaaan7 小时前
代码随想录Day31动态规划:1049最后一块石头的重量II_494目标和_474一和零
算法·动态规划
Jay Kay7 小时前
GVPO:Group Variance Policy Optimization
人工智能·算法·机器学习
Epiphany.5567 小时前
蓝桥杯备赛题目-----爆破
算法·职场和发展·蓝桥杯
YuTaoShao8 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法三)DP 空间优化
算法·leetcode·职场和发展
茉莉玫瑰花茶8 小时前
C++ 17 详细特性解析(5)
开发语言·c++·算法