传送门
题目大意:
交互题,

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,都可以满足要求。

代码:

  1. #include<bits/stdc++.h>
  2. #include<unordered_map>
  3. #include<unordered_set>
  4. using namespace std;
  5. typedef long long LL;
  6. typedef unsigned long long ULL;
  7. typedef pair<int, int> PII;
  8. //#define int LL
  9. //#define endl '\n'
  10. #define inf 0x3f3f3f3f
  11. #define INF 0x3f3f3f3f3f3f3f3f
  12. #define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
  13. #pragma warning(disable :4996)
  14. const double eps = 1e-8;
  15. const LL mod = 1000000007;
  16. const LL MOD = 998244353;
  17. const int maxn = 1010;
  18. int T, N;
  19. bool used[maxn];
  20. void solve()
  21. {
  22. PII res[4];
  23. vector<int>num;
  24. int lst = N, pos = 1, tmp, ans;
  25. while (lst > 3)
  26. {
  27. while (num.size() < 4)
  28. {
  29. if (!used[pos])
  30. num.push_back(pos);
  31. pos++;
  32. }
  33. for (int i = 0; i < 4; i++)
  34. {
  35. cout << "? " << num[i] << ' ' << num[(i + 1) % 4] << ' ' << num[(i + 2) % 4] << endl;
  36. cin >> ans;
  37. res[i] = PII(ans, num[(i + 3) % 4]);
  38. }
  39. sort(res, res + 4);
  40. int a = res[2].second, b = res[3].second;
  41. used[a] = used[b] = true;
  42. num.erase(find(num.begin(), num.end(), a)), num.erase(find(num.begin(), num.end(), b));
  43. tmp = a;
  44. lst -= 2;
  45. }
  46. if (lst == 2)
  47. cout << "! " << num[0] << ' ' << num[1] << endl;
  48. else
  49. {
  50. while (num.size() < 3)
  51. {
  52. if (!used[pos])
  53. num.push_back(pos);
  54. pos++;
  55. }
  56. num.push_back(tmp);
  57. for (int i = 0; i < 4; i++)
  58. {
  59. cout << "? " << num[i] << ' ' << num[(i + 1) % 4] << ' ' << num[(i + 2) % 4] << endl;
  60. cin >> ans;
  61. res[i] = PII(ans, num[(i + 3) % 4]);
  62. }
  63. sort(res, res + 4);
  64. int a = res[2].second, b = res[3].second;
  65. used[a] = used[b] = true;
  66. num.erase(find(num.begin(), num.end(), a)), num.erase(find(num.begin(), num.end(), b));
  67. cout << "! " << num[0] << ' ' << num[1] << endl;
  68. }
  69. }
  70. int main()
  71. {
  72. IOS;
  73. cin >> T;
  74. while (T--)
  75. {
  76. cin >> N;
  77. memset(used, false, sizeof(used));
  78. solve();
  79. }
  80. return 0;
  81. }

Codeforces Round #770 (Div. 2)D的更多相关文章

  1. 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 ...

  2. Codeforces Round #354 (Div. 2) ABCD

    Codeforces Round #354 (Div. 2) Problems     # Name     A Nicholas and Permutation standard input/out ...

  3. Codeforces Round #368 (Div. 2)

    直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...

  4. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  5. Codeforces Round #279 (Div. 2) ABCDE

    Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems     # Name     A Team Olympiad standard input/outpu ...

  6. 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 ...

  7. 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 ...

  8. Codeforces Round #371 (Div. 1)

    A: 题目大意: 在一个multiset中要求支持3种操作: 1.增加一个数 2.删去一个数 3.给出一个01序列,问multiset中有多少这样的数,把它的十进制表示中的奇数改成1,偶数改成0后和给 ...

  9. Codeforces Round #268 (Div. 2) ABCD

    CF469 Codeforces Round #268 (Div. 2) http://codeforces.com/contest/469 开学了,时间少,水题就不写题解了,不水的题也不写这么详细了 ...

随机推荐

  1. MacBook USB 连 iPhone 响个不停,充电频繁的连上/断开

    电脑是 MacBook Pro (Retina, 15-inch, Mid 2015) 连 iPhone 响个不停,充电频繁的连上 /断开,数据线是原装的,想连接爱思助手连接不上. 网上方法 1 开启 ...

  2. Java 中对象锁和类锁的区别? 关键字 Synchronized的用法?

    一  对象锁和类锁的关系 /* * 对象锁和[类锁] 全局锁的关系? 对象锁是用于对象实例方法,或者一个对象实例上的 this 类锁是用于类的静态方法或者一个类的class对象上的. Ag.class ...

  3. 解决No artifacts

    前言:maven管理项目时显示No artifacts 错误: 第一步:找到Artifacts 第二步:点击添加 第三步:点击exploded,然后点击应用即可 注意: 名字1和名字2一定要相同 最后 ...

  4. 【转】C# / Extension 扩展方法

    扩展方法简介扩展方法使你能够向现有类型"添加"方法,而无需创建新的派生类型.重新编译或以其他方式修改原始类型. 扩展方法是一种特殊的静态方法,但可以像扩展类型上的实例方法一样进行调 ...

  5. nginx入门教程 (转)

    1.Nginx 状态码配置和错误文件 server { # 配置访问 /test.js 时报 403 错 location /test.js { return 403; } # 配置访问 /404 时 ...

  6. eclipse中快捷键中逗号是怎么用的,如ctrl+2,L

    Ctrl +2 同时按下,松开后,再按下L

  7. C#中的字符串拼接@,$

    转载自:https://blog.csdn.net/qq_40666620/article/details/101695138 一:@ @的意思是以@标注的字符出,其中所有的符号均为字符串符号,没有什 ...

  8. 转载_认识C语言的32个关键字

    简单介绍: 1 auto : 声明自动变量 2 short :声明短整型变量或函数 3 int: 声明整型变量或函数 4 long :声明长整型变量或函数 5 float:声明浮点型变量或函数 6 d ...

  9. hibernate中的映射文件xxx.hbm.xml详解总结

    转自 http://blog.csdn.net/a9529lty/article/details/6454924 一.hibernate映射文件的作用: Hibernate映射文件是Hibernate ...

  10. CSS解决父级边框坍塌的问题

    1. 浮动元素后面增加空的div 首先在父级标签内添加如下<div>标签 <div id="clear"></div> 然后在CSS中对该标签进 ...