【双指针】【数之和】 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]会溢出,所以用减法不会溢出;

相关推荐
m0_7488394918 小时前
利用C 图形界面展示MATLAB算法的高效混合编程实践
开发语言·算法·matlab
进击的荆棘18 小时前
优选算法——哈希表
c++·算法·leetcode·哈希算法·散列表
阿牛大牛中18 小时前
阿里-RecGPT-Mobile
大数据·人工智能·算法
RH23121118 小时前
2026.5.17数据结构 八大排序
数据结构·算法·排序算法
加号318 小时前
【C#】 实现 CRC16 校验:原理、算法与工程实践
算法·c#
khalil102018 小时前
代码随想录算法训练营Day-55 图论06 | 108.冗余连接、109.冗余连接II
c++·算法·leetcode·图论·并查集
进击的荆棘18 小时前
优选算法——字符串
开发语言·c++·算法·leetcode·字符串
夏日听雨眠18 小时前
排序(直接插入排序,希尔排序)
数据结构·算法·排序算法
Kiling_070418 小时前
Java Map集合详解与实战
java·开发语言·python·算法
WL_Aurora18 小时前
备战蓝桥杯国赛【Day 18】
python·算法·蓝桥杯