Codeforces Round #770 (Div. 2)D
传送门
题目大意:
交互题,
n
(
4
≤
n
≤
1000
)
n(4\leq n\leq1000)
n(4≤n≤1000)个数字组成的数列
a
1
,
a
2
,
…
,
a
n
(
0
≤
a
i
≤
1
0
9
)
a_{1},a_{2},…,a_{n}(0\leq a_{i}\leq10^9)
a1,a2,…,an(0≤ai≤109),有且仅有
1
1
1个
0
0
0,每次询问
i
,
j
,
k
i,j,k
i,j,k,会给出
m
a
x
(
a
i
,
a
j
,
a
k
)
−
m
i
n
(
a
i
,
a
j
,
a
k
)
max(a_{i},a{j},a{k})-min(a_{i},a_{j},a_{k})
max(ai,aj,ak)−min(ai,aj,ak)的值,最多询问
2
n
−
2
2n-2
2n−2次,最后需要输出
i
,
j
i,j
i,j,使
a
i
,
a
j
a_{i},a_{j}
ai,aj当中有一个为
0
0
0。
思路:
题目可以转化为找出
n
−
2
n-2
n−2个绝对不会为
0
0
0的位置。我们考虑
4
4
4个数字
0
,
a
,
b
,
c
0,a,b,c
0,a,b,c,不妨设
0
<
a
≤
b
≤
c
0<a\leq b\leq c
0<a≤b≤c,那么在
4
4
4个数当中,我们记不选数字
a
a
a而选择了其他
3
3
3个数字询问而得到的答案记为
a
′
a'
a′,那么上面的例子中,
0
′
=
c
−
a
,
a
′
=
c
,
b
′
=
c
,
c
′
=
b
0'=c-a,a'=c,b'=c,c'=b
0′=c−a,a′=c,b′=c,c′=b,这
4
4
4个
a
n
s
ans
ans中最大的两个值所对应的位置一定不会为
0
0
0,因为如果为
0
0
0,那么舍弃掉既不是
0
0
0也不是这
4
4
4个当中最大值的两个位置中的一个去询问会得到的回答是这
4
4
4个数当中的最大值,一定比舍弃掉
0
0
0的询问更大,所以我们可以把
4
4
4个
a
n
s
ans
ans中最大的两个位置去掉,这样通过每轮
4
4
4个询问我们可以排除掉两个位置,(
4
4
4位置都没有
0
0
0的情况下也可以这样算,都不是
0
0
0去掉两个显然没有问题)当
n
n
n为偶数时,我们只需要询问
n
−
2
2
∗
4
=
2
n
−
4
\frac{n-2}{2}*4=2n-4
2n−2∗4=2n−4次,而如果为奇数,最后会剩余
3
3
3个没有去掉的位置,我们只需要把之前任意一个去掉过的位置拿过来凑够
4
4
4个再进行
1
1
1轮即可,总的询问次数时
n
−
3
2
∗
4
+
4
=
2
n
−
2
\frac{n-3}{2}*4+4=2n-2
2n−3∗4+4=2n−2,都可以满足要求。
代码:
#include<bits/stdc++.h>
#include<unordered_map>
#include<unordered_set>
using namespace std;
typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int, int> PII;
//#define int LL
//#define endl '\n'
#define inf 0x3f3f3f3f
#define INF 0x3f3f3f3f3f3f3f3f
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
#pragma warning(disable :4996)
const double eps = 1e-8;
const LL mod = 1000000007;
const LL MOD = 998244353;
const int maxn = 1010;
int T, N;
bool used[maxn];
void solve()
{
PII res[4];
vector<int>num;
int lst = N, pos = 1, tmp, ans;
while (lst > 3)
{
while (num.size() < 4)
{
if (!used[pos])
num.push_back(pos);
pos++;
}
for (int i = 0; i < 4; i++)
{
cout << "? " << num[i] << ' ' << num[(i + 1) % 4] << ' ' << num[(i + 2) % 4] << endl;
cin >> ans;
res[i] = PII(ans, num[(i + 3) % 4]);
}
sort(res, res + 4);
int a = res[2].second, b = res[3].second;
used[a] = used[b] = true;
num.erase(find(num.begin(), num.end(), a)), num.erase(find(num.begin(), num.end(), b));
tmp = a;
lst -= 2;
}
if (lst == 2)
cout << "! " << num[0] << ' ' << num[1] << endl;
else
{
while (num.size() < 3)
{
if (!used[pos])
num.push_back(pos);
pos++;
}
num.push_back(tmp);
for (int i = 0; i < 4; i++)
{
cout << "? " << num[i] << ' ' << num[(i + 1) % 4] << ' ' << num[(i + 2) % 4] << endl;
cin >> ans;
res[i] = PII(ans, num[(i + 3) % 4]);
}
sort(res, res + 4);
int a = res[2].second, b = res[3].second;
used[a] = used[b] = true;
num.erase(find(num.begin(), num.end(), a)), num.erase(find(num.begin(), num.end(), b));
cout << "! " << num[0] << ' ' << num[1] << endl;
}
}
int main()
{
IOS;
cin >> T;
while (T--)
{
cin >> N;
memset(used, false, sizeof(used));
solve();
}
return 0;
}
Codeforces Round #770 (Div. 2)D的更多相关文章
- Codeforces Round #366 (Div. 2) ABC
Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...
- Codeforces Round #354 (Div. 2) ABCD
Codeforces Round #354 (Div. 2) Problems # Name A Nicholas and Permutation standard input/out ...
- Codeforces Round #368 (Div. 2)
直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- Codeforces Round #279 (Div. 2) ABCDE
Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems # Name A Team Olympiad standard input/outpu ...
- Codeforces Round #262 (Div. 2) 1003
Codeforces Round #262 (Div. 2) 1003 C. Present time limit per test 2 seconds memory limit per test 2 ...
- Codeforces Round #262 (Div. 2) 1004
Codeforces Round #262 (Div. 2) 1004 D. Little Victor and Set time limit per test 1 second memory lim ...
- Codeforces Round #371 (Div. 1)
A: 题目大意: 在一个multiset中要求支持3种操作: 1.增加一个数 2.删去一个数 3.给出一个01序列,问multiset中有多少这样的数,把它的十进制表示中的奇数改成1,偶数改成0后和给 ...
- Codeforces Round #268 (Div. 2) ABCD
CF469 Codeforces Round #268 (Div. 2) http://codeforces.com/contest/469 开学了,时间少,水题就不写题解了,不水的题也不写这么详细了 ...
随机推荐
- Java编程中标识符注意点以及注释
标识符注意点 所有的标识符都应该以字母(A-Z或者a-z),美元符($),或者下划线(_)开始 首字符之后可以是字母(A-Z或者a-z),美元符($),下划线(_)或数 字的任何字符组合 不能使用关键 ...
- Web3对于我们普通人意味着什么?
▲ 点击101链视界,关注不走丢 大家好,我是阿创,这是我的第27篇原创文章. 上一篇文章中我们了解了互联网的前世今生:Web 1.0.2.0.3.0,我们对Web的前两个阶段都不陌生,特别是 Web ...
- 在windows、widfly环境下,远程debug
最近:一直想弄一个远程debug模式,奈何没有接触过,导致畏首畏尾,不过,两天时间终于搞出来了雏形,真的是一个坑一个坑踩过来的. widfly环境:widfly8 准备工作:远程运行环境:省略,前面一 ...
- JVM学习五:性能监控工具
一.系统性能监控 系统性能工具用于确定系统运行的整体状态,基本定位问题所在. Linux – uptime • 系统时间 • 运行时间 n 例子中为7分钟 • 连接数 n 每一个终端算一个连接 • 1 ...
- linux安装python3.6.6和新建虚拟环境
基础准备 修改本地时区 cp -rf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime 安装epel yum源 yum -y install epel- ...
- 如何快速为团队打造自己的组件库(下)—— 基于 element-ui 为团队打造自己的组件库
文章已收录到 github,欢迎 Watch 和 Star. 简介 在了解 Element 源码架构 的基础上,接下来我们基于 element-ui 为团队打造自己的组件库. 主题配置 基础组件库在 ...
- Windows office2019免费激活,附代码
office2019地址:链接:https://pan.baidu.com/s/1zPt5U7b0L-bGHl5AOtYs2w提取码:m5ei 新建一个txt,然后把这段代码放进去,然后保存关闭改后缀 ...
- P1015 [NOIP1999 普及组] 回文数
点击查看题目 题目描述 若一个数(首位不为零)从左向右读与从右向左读都一样,我们就将其称之为回文数. 例如:给定一个十进制数 5656,将 5656 加 6565(即把 5656 从右向左读),得到 ...
- Solution -「CodeChef JUMP」Jump Mission
\(\mathcal{Description}\) Link. 有 \(n\) 个编号 \(1\sim n\) 的格子排成一排,并有三个权值序列 \(\{a_n\},\{h_n\},\{p_n ...
- php发送邮件 (phpmailer)
1.首先下载phpMailer文件官方文件https://sourceforge.net/projects/phpmailer/: 还有class.smtp.php. 2.去配置一下发送邮件的服务器, ...