TAG- 双指针 双指针 双指针时间复杂度- O ( D ) O(\sqrt D) O(D)
//
#include<bits/stdc++.h>
using namespace std;
#define int long long
void solve()
{
int d;
scanf("%lld",&d );
int ans=d;
int i=0,j=sqrt(d)+1; // for non-negative integers x and y.
while( i<=j )
{
int sum=i*i+j*j;
ans=min( ans,abs( i*i+j*j-d ) );
if( sum>=d ) j--;
else i++;
}
printf("%d",ans );
}
signed main()
{
int t=1;
// scanf("%d",&t );
while( t-- ) solve();
return 0;
}
实现细节
非负数
参考示意图
- 无
参考链接
- 无
作者 | 乐意奥AI
本文介绍了如何使用C++实现一个双指针算法,用于求解给定非负整数d下,使i*i+j*j最接近但不超过d的最小绝对差值。算法的时间复杂度为O(sqrt(D))。
1528

被折叠的 条评论
为什么被折叠?



