HDU OJ 4334 Trouble 2012 Multi-University Training Contest 4
题目:click here
题意:
给定5组数据,每组数据选择一个数,看是否能找到5个数的和为零。
分析:
千万不要~~T~~
普通线性查找:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm> using namespace std;
typedef long long ll;
const int INF = 0x3f3f3f3f;
const int M = ; int t, n;
ll a[][M]; // 5组数据
ll pre[M*M]; // 第一二组数据两两和
ll nex[M*M]; // 第三四组数据两两和
ll lef[M]; // 最后一组数据 void solve() {
scanf("%d", &n );
for( int i=; i<; i++ )
for( int j=; j<n; j++ )
scanf("%I64d", &a[i][j] );
int pos = ;
for( int i=; i<n; i++ )
for( int j=; j<n; j++ )
pre[pos++] = a[][i] + a[][j];
pos = ;
for( int i=; i<n; i++ )
for( int j=; j<n; j++ )
nex[pos++] = a[][i] + a[][j];
ll maxn = n*n;
for( int i=; i<n; i++ )
lef[i] = a[][i];
sort( pre, pre+maxn ); // 排序
sort( nex, nex+maxn );
sort( lef, lef+n );
for( int i=; i<n; i++ ) {
int left = , right = maxn-;
while( left<maxn && right >= ) { // 两个指针最多改变40000+40000次
ll sum = pre[left] + nex[right];
if( sum == -lef[i] ) {
printf("Yes\n"); return ;
}
else if( sum > -lef[i] ) right--;
else left++;
}
}
printf("No\n");
} int main() {
scanf("%d", &t );
while( t-- )
solve();
}
hash:(第一次碰到hash的题---不解释~~我也不懂)
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <set> using namespace std;
typedef __int64 ll;
const int INF = 0x3f3f3f3f;
const int MOD = 4e5+;
const int M = ; int t, n;
ll a[][M];
ll g[MOD];
ll sum;
bool f[MOD]; int fhash( ll x ) {
int p = x%MOD;
if( p < ) p += MOD;
while( f[p] && g[p] != x )
p = (p+)%MOD;
return p;
}
void solve() {
scanf("%d", &n );
for( int i=; i<; i++ )
for( int j=; j<n; j++ )
scanf("%I64d", &a[i][j] );
memset( f, false, sizeof(f) );
for( int i=; i<n; i++ ) {
for( int j=; j<n; j++ ) {
sum = a[][i] + a[][j];
int p = fhash( sum );
f[p] = true;
g[p] = sum;
}
}
for( int i=; i<n; i++ ) {
for( int j=; j<n; j++ ) {
for( int k=; k<n; k++ ) {
sum = a[][i] + a[][j] + a[][k];
int p = fhash( -sum );
if( f[p] ) {
printf("Yes\n");
return ;
}
}
}
}
printf("No\n");
}
int main() {
scanf("%d", &t );
while( t-- )
solve();
}
HDU OJ 4334 Trouble 2012 Multi-University Training Contest 4的更多相关文章
- HDU 6091 - Rikka with Match | 2017 Multi-University Training Contest 5
思路来自 某FXXL 不过复杂度咋算的.. /* HDU 6091 - Rikka with Match [ 树形DP ] | 2017 Multi-University Training Conte ...
- HDU 6125 - Free from square | 2017 Multi-University Training Contest 7
思路来自这里 - - /* HDU 6125 - Free from square [ 分组,状压,DP ] | 2017 Multi-University Training Contest 7 题意 ...
- HDU 6129 - Just do it | 2017 Multi-University Training Contest 7
比赛时脑子一直想着按位卷积... 按题解的思路: /* HDU 6129 - Just do it [ 规律,组合数 ] | 2017 Multi-University Training Contes ...
- HDU 6088 - Rikka with Rock-paper-scissors | 2017 Multi-University Training Contest 5
思路和任意模数FFT模板都来自 这里 看了一晚上那篇<再探快速傅里叶变换>还是懵得不行,可能水平还没到- - 只能先存个模板了,这题单模数NTT跑了5.9s,没敢写三模数NTT,可能姿势太 ...
- HDU 6093 - Rikka with Number | 2017 Multi-University Training Contest 5
JAVA+大数搞了一遍- - 不是很麻烦- - /* HDU 6093 - Rikka with Number [ 进制转换,康托展开,大数 ] | 2017 Multi-University Tra ...
- HDU 6085 - Rikka with Candies | 2017 Multi-University Training Contest 5
看了标程的压位,才知道压位也能很容易写- - /* HDU 6085 - Rikka with Candies [ 压位 ] | 2017 Multi-University Training Cont ...
- HDU 6073 - Matching In Multiplication | 2017 Multi-University Training Contest 4
/* HDU 6073 - Matching In Multiplication [ 图论 ] | 2017 Multi-University Training Contest 4 题意: 定义一张二 ...
- HDU 6057 - Kanade's convolution | 2017 Multi-University Training Contest 3
/* HDU 6057 - Kanade's convolution [ FWT ] | 2017 Multi-University Training Contest 3 题意: 给定两个序列 A[0 ...
- HDU 6061 - RXD and functions | 2017 Multi-University Training Contest 3
每次NTT都忘记初始化,真的是写一个小时,Debug两个小时- - /* HDU 6061 - RXD and functions [ NTT ] | 2017 Multi-University Tr ...
随机推荐
- MyBatis 最常见错误,启动时控制台无限输出日志
你是否遇到过下面的情况,控制台无限的输出下面的日志: Logging initialized using ‘class org.apache.ibatis.logging.log4j.Log4jImp ...
- Windows Azure 社区新闻综述(#71 版)
欢迎查看最新版本的每周综述,其中包含有关云计算和 Windows Azure的社区推动新闻.内容和对话. 以下是过去一周基于您的反馈汇集在一起的内容: 文章.视频和博客文章 · 使用 Azure ...
- css首行缩进两个字符串
text-indent:2em; 这个属性就可以缩进,但是2em不确定是什么意思:抽空总结一下
- C++四种强制类型转换详解
什么是类型转换? 类型转换的含义是通过改变一个变量的类型为别的类型从而改变该变量的表示方式.为了类型转换一个简单对象为另一个对象你会使用传统的类型转换操作符. C与C++的类型转换 //C中: //复 ...
- iOS 更改导航栏返回button文字
假如有两个ViewController A,B 改动B的返回button需在A页面设置 self.navigationItem.backBarButtonItem = [[UIBarButtonIte ...
- ASP.NET listBbox控件用法
ListBox基本功能使用方法 2011-06-09 13:23:16| 分类: .NET/C# | 标签:listbox基本功能使用方法 |举报 |字号大中小 订阅 ListBox基 ...
- JS学习笔记(一)基本数据类型和对象类型
js是一种弱类型的语言,所有的变量都用var进行声明,字符串用双引号或单引号括起来,常见基本数据类型为number,string,boolean等.如 var num = 123;或var num = ...
- 使用window.postMessage实现跨域通信
JavaScript由于同源策略的限制,跨域通信一直是棘手的问题.当然解决方案也有很多: document.domain+iframe的设置,应用于主域相同而子域不同: 利用iframe和locati ...
- log4j 详解
转载自:http://www.blogjava.net/hwpok/archive/2008/08/23/223891.html >>>>1. 概述<<< ...
- Putty以及adb网络调试
1.什么是SSH? SSH 为 Secure Shell 的缩写,由 IETF 的网络工作小组(Network Working Group)所制定:SSH 为建立在应用层和传输层基础上的安全协议. 传 ...