【双指针】【数之和】 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;

    }
};

但注意一点,dpl + dpr会溢出,所以用减法不会溢出;

相关推荐
随意起个昵称1 分钟前
线性dp-计数类题目11(不等数列)
c++·算法·动态规划
Black蜡笔小新9 分钟前
自动化AI算法训练服务器DLTM零代码私有化部署筑牢企业AI落地根基
人工智能·算法·自动化
wWYy.10 分钟前
算法:最大子数组和
算法
吃着火锅x唱着歌13 分钟前
LeetCode 3829.设计共享出行系统
算法·leetcode·职场和发展
炸薯条!15 分钟前
二叉树的链式表示
数据结构·算法
CHHH_HHH16 分钟前
【C++】二叉搜索树全面升级,深度剖析AVL树
开发语言·数据结构·c++·算法·stl
Mumu121817 分钟前
P3211 [HNOI2011] XOR和路径
算法
高一学习c++会秃头吗18 分钟前
页面置换算法实现
算法
yuanyuan2o225 分钟前
Transformers NLP 任务:阅读理解问答
人工智能·算法·自然语言处理·nlp·github
菜菜的顾清寒36 分钟前
力扣HOT100(52)动态规划 - 最长递增子序列
算法·leetcode·动态规划