平方数之和(力扣)双指针 JAVA

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

示例 1:

输入:c = 5

输出:true

解释:1 * 1 + 2 * 2 = 5

示例 2:

输入:c = 3

输出:false

提示:

0 <= c <= 2^31 - 1

解题思路:

1、采用双指针在构建的二维矩阵中查找

2、得用long类型变量

3、l = 0, r = Math.sqrt( c )

代码:

java 复制代码
class Solution {
    public boolean judgeSquareSum(int c) {
         long l = 0, r = (long) Math.sqrt(c);
         while(l <= r) {
        	 if(l * l + r * r > c) r --;
        	 else if(l * l + r * r < c) l ++;
        	 else return true;
         }
         return false;
    }
}
相关推荐
摇滚侠2 分钟前
Unsupported class file major version 61
java·maven
那个失眠的夜3 分钟前
Arrays&Lambda&JDK8新特性
java
搬砖的小码农_Sky4 分钟前
比特币区块链的算法架构
算法·架构·去中心化·区块链
流年如夢8 分钟前
顺序表(LeetCode)
c语言·数据结构·leetcode·职场和发展
ch.ju8 分钟前
Java程序设计(第3版)第二章——空返回值
java
say_fall14 分钟前
校招必看:八大排序算法原理、复杂度与高频面试题
数据结构·c++·算法·排序算法
草莓熊Lotso17 分钟前
LangChain从入门到精通:环境搭建→核心能力→LCEL链式编程全实战
android·java·linux·服务器·langchain
贾斯汀玛尔斯9 小时前
每天学一个算法--LSM-Tree(Log-Structured Merge Tree)
java·算法·lsm-tree
bitt TRES9 小时前
springboot与springcloud对应版本
java·spring boot·spring cloud
Y001112369 小时前
JavaWeb-end
java·servlet·web