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 ...
随机推荐
- USB OTG ID 检测原理
OTG 检测的原理是: USB OTG标准在完全兼容USB2.0标准的基础上,增添了电源管理(节省功耗)功能,它允许设备既可作为主机,也可作为外设操作(两用OTG).USB OTG技术可实现没有主机时 ...
- 今天在发布IIS站点的时候遇到了一些问题
1.HTTP 错误 500.23 - Internal Server Error 检测到在集成的托管管道模式下不适用的 ASP.NET 设置. 分析:一般5XX的错误都是服务器的问题,这里把应用程序池 ...
- iOS开发之主题皮肤
iOS开发之主题皮肤 分类: [iOS] 最近在开发一款[公交应用],里面有个模块涉及到主题设置,这篇文章主要谈一下个人的做法. 大概的步骤如下: (1):整个应用依赖于一个主题管理器,主题管理器根 ...
- DKNY_百度百科
DKNY_百度百科 DKNY
- Node.js开发指南中的例子(mysql版)
工作原因需要用到nodejs,于是找到了<node.js开发指南>这本书来看看,作者BYVoid 为清华大学计算机系的高材生,年纪竟比我还小一两岁,中华地广物博真是人才辈出,佩服. 言归正 ...
- Kali linux安装漏洞扫描工具Nessus指南
引子:Nessus是著名信息安全服务公司tenable推出的一款漏洞扫描与分析软件,号称是"世界上最流行的漏洞扫描程序,全世界超过75,000个组织在使用它".虽然这个扫描程序能够 ...
- BFC / hasLayout
BFC - block formatting context 1.float的值不能为none 2.overflow的值不能为visible 3.display的值为table-cell,table- ...
- WPF-MVC开发模式简要介绍
1, 建立WPF程序,并在程序中添加三个文件View,ViewMoudle,Moudle, 2,Moudle文件加中添加类,此文件夹中存放的类基本为数据类,主要是字段和属性 3 ViewMoudle文 ...
- IO库 8.5
题目:重写8.4中的函数,将每一个单词作为一个独立的元素进行存储. #include <iostream> #include <fstream> #include <st ...
- 理解ROS的参数
记住每次操作之前都要在一个单独的终端中运行ros的核心. roscore rosparam命令允许你在ROS的参数服务器上操作和存储数据,参数服务器可以存储整数,浮点数,布尔类型,字典,列表.ROS使 ...