【双指针】【数之和】 LeetCode 633.平方数之和

算法思想:

  • 双指针枚举i,j;类似三数之和
cpp 复制代码
class Solution {
public:
    bool judgeSquareSum(int c) {
        long long  sum=0;
        vector<int> dp;dp.push_back(0);
        long long start=1;
        while(sum < c)
        {
            sum = start *start;
            if(sum>c) break;
            else dp.push_back(sum);
            start++;

        }
        long long l=0,r=dp.size()-1;
        while(l<=r)
        {
            //long long tmp =dp[l] + dp[r]; 会溢出
            if(dp[l] < c-dp[r])
            {
                l++;
                continue;
            }
            else if (dp[l] > c - dp[r])
            {
                r--;
                continue;
            }
            else if(dp[l] == c-dp[r]) return true;
        }
        return false;

    }
};

但注意一点,dp[l] + dp[r]会溢出,所以用减法不会溢出;

相关推荐
仙俊红5 小时前
LeetCode每日一题,20250914
算法·leetcode·职场和发展
风中的微尘11 小时前
39.网络流入门
开发语言·网络·c++·算法
西红柿维生素12 小时前
JVM相关总结
java·jvm·算法
ChillJavaGuy14 小时前
常见限流算法详解与对比
java·算法·限流算法
sali-tec14 小时前
C# 基于halcon的视觉工作流-章34-环状测量
开发语言·图像处理·算法·计算机视觉·c#
你怎么知道我是队长15 小时前
C语言---循环结构
c语言·开发语言·算法
艾醒15 小时前
大模型面试题剖析:RAG中的文本分割策略
人工智能·算法
纪元A梦18 小时前
贪心算法应用:K-Means++初始化详解
算法·贪心算法·kmeans
_不会dp不改名_18 小时前
leetcode_21 合并两个有序链表
算法·leetcode·链表
mark-puls18 小时前
C语言打印爱心
c语言·开发语言·算法