当前位置: 首页> 娱乐> 影视 > 洛谷U420301题解

洛谷U420301题解

时间:2025/8/10 5:01:25来源:https://blog.csdn.net/weixin_68756152/article/details/139991109 浏览次数:0次

题解

方法一枚举

时间复杂度 O ( n 2 ) O(n^2) O(n2)
主要代码

int main()
{int n,t;cin >> n;for(int i = 1;i <= n;i++)   cin >> a[i];cin >> t;for(int i = 1;i <= n;i++){for(int j = i + 1;j <= n;j++){if(a[i] + a[j] == t){cout << "Yes" << endl;return 0;}}}cout << "No" << endl;return 0;
}
方法二二分查找

先选定 a i a_i ai,然后在数组 a a a 里找找 t − a i t-a_i tai 有没有
时间复杂度 O ( n l o g n ) O(nlogn) O(nlogn)

代码
#include <bits/stdc++.h>
using namespace std;
int n,a[1000010];
bool check(int x,int i)
{int* k = lower_bound(a + i + 1,a + n + 1,x);if(k - a > n)   return false;return *k == x;
}
signed main()
{cin >> n;for(int i = 1;i <= n;i++){cin >> a[i];}int t;cin >> t;for(int i = 1;i <= n;i++){int x = t - a[i];if(check(x,i)){cout << "Yes" << endl;return 0;}}cout << "No" << endl;return 0;
}
关键字:洛谷U420301题解

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: