JavaInterview JavaInterview
首页
指南
分类
标签
归档
  • CSDN (opens new window)
  • 文档集合 (opens new window)
  • 系统架构 (opens new window)
  • 微信号 (opens new window)
  • 公众号 (opens new window)

『Java面试+Java学习』
首页
指南
分类
标签
归档
  • CSDN (opens new window)
  • 文档集合 (opens new window)
  • 系统架构 (opens new window)
  • 微信号 (opens new window)
  • 公众号 (opens new window)
  • 指南
  • 简历

  • Java

  • 面试

  • 算法

  • algorithm
  • leetcode
JavaInterview.cn
2022-09-17
目录

平方数之和Java

文章发布较早,内容可能过时,阅读注意甄别。

# 题目

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

示例 1:

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

示例 2:

输入:c = 3
输出:false

提示:

  • 0 <= c <= 231 - 1

# 思路

// 如果存在符合条件的a,b,那么a和b一定在0和sqrt(c)之间。
// 最朴素的思路,两层for循环,从0到sqrt(c),看是否存在符合条件的a和b。相当于遍历了两次从0到sqrt(c)
// 显然,没有双指针快捷,双指针只需要遍历一次即可。**为什么使用双指针不会把正确答案排除在外呢**。我认为这才是需要认真考虑的问题,而不是双指针直接用。我们用a表示第一个数,b表示第二个数。从初始开始考虑,a = 0,b = (int)Math.sqrt(c)
// if(a*a+b*b<c),那么显然,a固定的情况下和无论如何变化b值都不会满足当前的条件,由此,**a=0一定不在正确答案中**,所以可以直接排除。
// 反之,if(a*a+b*b>c),b固定的情况下,当前所有能变化的a值,都不会满足条件,因此,**当前的b也一定不在正确答案中**。
// 综上,双指针法确保正确答案不会被排除。

# 解法


class Solution {

// 如果存在符合条件的a,b,那么a和b一定在0和sqrt(c)之间。
// 最朴素的思路,两层for循环,从0到sqrt(c),看是否存在符合条件的a和b。相当于遍历了两次从0到sqrt(c)
// 显然,没有双指针快捷,双指针只需要遍历一次即可。**为什么使用双指针不会把正确答案排除在外呢**。我认为这才是需要认真考虑的问题,而不是双指针直接用。我们用a表示第一个数,b表示第二个数。从初始开始考虑,a = 0,b = (int)Math.sqrt(c)
// if(a*a+b*b<c),那么显然,a固定的情况下和无论如何变化b值都不会满足当前的条件,由此,**a=0一定不在正确答案中**,所以可以直接排除。
// 反之,if(a*a+b*b>c),b固定的情况下,当前所有能变化的a值,都不会满足条件,因此,**当前的b也一定不在正确答案中**。
// 综上,双指针法确保正确答案不会被排除。
    public boolean judgeSquareSum(int c) {
        long a = 0;
        long b = (long)Math.sqrt(c);
        while(a <= b){
            if(a*a+b*b<c){
                a++;
            }else if(a*a+b*b>c){
                b--;
            }else{
                return true;
            }
        }
        
        return false;
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

# 总结

  • 分析出几种情况,然后分别对各个情况实现
微信 支付宝
最近更新
01
1686. 石子游戏VI Java
08-18
02
1688. 比赛中的配对次数 Java
08-18
03
1687. 从仓库到码头运输箱子 Java
08-18
更多文章>
Theme by Vdoing | Copyright © 2019-2025 JavaInterview.cn
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式