平方数之和(力扣)双指针 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;
    }
}
相关推荐
寻寻觅觅☆4 分钟前
东华OJ-基础题-127-我素故我在(C++)
开发语言·c++·算法
ab1515175 分钟前
2.13完成101、102、89
开发语言·c++·算法
黎潇lulu20 分钟前
Java运算符基础知识
java·开发语言
HAPPY酷24 分钟前
C++中类常见的函数分类
java·开发语言·c++
小钻风336629 分钟前
JWT初识
java·jwt·base64url
weixin_4491736538 分钟前
java使用poi保存表格和图片到word文件中
java·开发语言·word
好家伙VCC1 小时前
# 光计算驱动的编程范式革新:用Python实现光子神经网络模拟器在传统电子计算架构逼近物理极限的今天,**光计算**正
java·开发语言·python·神经网络
月挽清风1 小时前
代码随想录第31天:贪心
算法
yqj2341 小时前
【无标题】
java·开发语言