HDOJ/HDU 2141 Can you find it? 二分搜索优化
来源:互联网 发布:锁屏也能抢红包的软件 编辑:程序博客网 时间:2024/05/22 00:28
题目:http://acm.hdu.edu.cn/showproblem.php?pid=2141
直接三重循环肯定超时了啊,O(n^3)是不允许的,现在把前两个数组加起来的每种情况保存,再用X-C[i]的值去做二分搜索,这样可以把复杂度降低到O(n^2+nlogn)就可以AC了,不过做二分搜索的时候一定要注意边界情况,不然会WA很多次,尼玛的!!
#include<stdio.h>#include<string.h>#include<math.h>#include<algorithm>#include<iostream> using namespace std;int a[505],b[505],c[505];int sum[505*505];int l,n,m,k;int flag;void binary(int x){int left,right,mid;left=0,right=k-1;while(left<=right){mid=(left+right)>>1;if(sum[mid]>x)right=mid-1;else if(sum[mid]<x)left=mid+1;else{flag=1;return ;}}return ;}int main(){int i,j,q,x,cnt=1;while(cin>>l>>n>>m){for(i=0;i<l;i++)scanf("%d",&a[i]);for(i=0;i<n;i++)scanf("%d",&b[i]);for(i=0;i<m;i++)scanf("%d",&c[i]);k=0;for(i=0;i<l;i++)for(j=0;j<n;j++){sum[k++]=a[i]+b[j];}sort(sum,sum+k);scanf("%d",&q);printf("Case %d:\n",cnt++);while(q--){scanf("%d",&x); flag=0;for(i=0;i<m;i++){binary(x-c[i]);if(flag){printf("YES\n");break;}}if(!flag)printf("NO\n");}}return 0;}
- HDOJ/HDU 2141 Can you find it? 二分搜索优化
- HDOJ 题目2141 Can you find it?(二分搜索)
- HDOJ Can you find it? 2141(二分搜索)
- HDOJ 2141 Can you find it?(二分搜索的优化+总结)
- hdu 2141Can you find it?(二分搜索)
- hdu-2141Can you find it?(二分搜索求和)
- hdoj-2141 Can you find it?【二分】
- hdu 2141 Can you find it? 【时间优化+二分】
- HDU/HDOJ 2141 Can you find it?
- hdu 2141 Can you find it? 二分
- HDU 2141 Can you find it?(二分)
- hdu 2141 Can you find it? 二分
- HDU 2141 Can you find it?【二分】
- 【HDU 2141】【二分】 Can you find it?
- HDU 2141 Can you find it? (二分)
- HDU-2141-Can you find it?【二分】
- HDU 2141 Can you find it?二分
- hdu 2141 Can you find it?(二分)
- Struts2-Download
- java在线支付---05_在线支付_编写用于准备请求数据的Servlet
- Memcached提升Web数据操作读写性能
- 项目文件或网站已移动或已重命名,或者不在您的计算机上
- sleep和write的区别
- HDOJ/HDU 2141 Can you find it? 二分搜索优化
- PHP缩小png图片,保留透明色方法
- 我的第二轮进攻开始了
- 人类无法抗拒的10种心理
- poj 1562 Oil Deposits(迷宫)
- java在线支付---06,07,08_在线支付_编写将数据提交给易宝支付的JSP页面,集成和测试向易宝发送支付请求,实现浏览器自动向易宝发送支付请求
- maven的安装
- linux内核-内存管理(上)
- 八大排序算法