2019.2.14 考试T3 交互题
\(\color{#0066ff}{ 题目描述 }\)
由于机房被成功拯救了,花_Q很高兴,花_Q生成了一个 0 到 N - 1 的排列(排列的下标从 0 到 N - 1 )。保证排列中 0 在 N - 1 的左边。
lzxkj一向很好奇,他想要知道这个排列是什么,但是由于lzxkj和阿习小pen友一起来的,的花_Q就是不告诉他。
阿习小pen友很聪明,Ta每次向花_Q询问一个区间 [l, r] ,花_Q 会告诉Ta区间 [l, r] 内的最大值减去最小值的值(极差)。阿习小朋友在不超过 10000 次询问后就从花_Q那里得到他的区间了。 lzxkj 很满意 假如你是阿习,你能还原出这个排列吗?
你需要在不超过10000次询问之内还原这个排列。
你不需要也不应该实现主函数,你需要实现如下函数:
get_permutation(N, ans)
其中 N 代表排列的长度,你需要将计算出来的答案保存在 ans 数组中, ans[i] 代表第 i 个位置的排列的值。
你可以调用 query(l, r) 来询问区间 [l, r] 的内的极差。你需要保证 0 <= l <= r <= N - 1 。
调用一次 query 函数的复杂度为 O(r - l + 1) 。
你需要提交一个源文件 permutation.cpp 并实现上述函数,并且遵循下面的命名和接口。
你的源代码中需要包含头文件 permutation.h 。
你需要实现的函数 get_permutation 定义如下:
void get_permutation(int N, int ans[]);
函数 query 的接口如下:
int query(int l, int r);
你需要在目录下使用如下命令编译得到可执行程序:
g++ grader.cpp permutation.cpp -o permutation -O2 -lm
可执行文件从标准输入读入以下格式的数据:
第一行包含一个整数N。需要保证N在 [1, 5000] 之间。
第二行包含 N 个 0 ~ N - 1 之间的正整数,表示 0 ~ N - 1 的排列。
你的输入要保证是一个排列。
读入完成后,交互库将会调用 get_permutation 函数。如果此时你调用 query 函数的次数超过 10000 次,则交互库会输出错误信息并退出。
当你的函数返回后,交互库会判断 ans 数组里的答案是否正确。如果正确则会输出 "Correct" ,否则会输出错误信息。
最终评测时只收取 permutation.cpp 。题目首先会受到和非交互式程序题相同的限制。例如编译错误会导致整道题目得 0 分,运行时错误、超过时间限制、超过空间限制等会导致相应测试点得 0 分等。你只能访问自己定义的和交互库给出的变量及其对应的内存空间,尝试访问其他空间将可能导致编译错误或运行错误。
在上述条件基础上,在一个测试点中,你得到满分,当且仅当你的每次调用都合法,并且最终返回的结果正确。
题目中所给的时间、空间限制为你的代码和交互库加起来可以使用的时间和空间。我们保证,对于任何合法的数据及在限制范围内的调用,交互库运行所用的时间不会超过 1s ,运行所占内存不会超过 128M ,也就是说,选手实际可用的时间至少为 1s ,实际可用内存至少为 384M 。
\(\color{#0066ff}{输入格式}\)
函数传参
\(\color{#0066ff}{输出格式}\)
将输出存入ans数组内
\(\color{#0066ff}{输入样例}\)
5
0 3 2 4 1
\(\color{#0066ff}{输出样例}\)
Correct
\(\color{#0066ff}{数据范围与提示}\)
一共有 20 个测试点,每个测试点 5 分。
对于 30% 的数据,有 N <= 100 。
对于 60% 的数据,有 N <= 1000 。
对于 100% 的数据,有 N <= 5000 。
\(\color{#0066ff}{ 题解 }\)
首先,钦定0为第一个
然后询问(0,1),钦定第二个为刚刚询问的ans
从第三个数开始,每次询问(i-2,i)和(i-1,i),记为a,b
到底是上一个数+b还是-b,讨论a是由这三个数中的哪两个数取得的,就可以唯一确定
最后的序列值域可能不是[0,n-1],同时减去最小值变回来
还有,0必须在n-1的左边,如果在右边,就让所有数变为(n-1-当前数),这样,差不变,0和n-1反向
就没了
#include"permutation.h"
#include<cstdio>
#include<iostream>
#define LL long long
LL in() {
char ch; LL x = 0, f = 1;
while(!isdigit(ch = getchar()))(ch == '-') && (f = -f);
for(x = ch ^ 48; isdigit(ch = getchar()); x = (x << 1) + (x << 3) + (ch ^ 48));
return x * f;
}
const int maxn = 5010;
bool flag;
int n;
int abs(int x) { return x > 0? x : -x; }
void get_permutation(int N, int ans[]) {
ans[0] = 0;
ans[1] = query(0, 1);
for(int i = 2; i < N; i++) {
int t1 = query(i - 2, i);
int t2 = query(i - 1, i);
int a = ans[i - 1] + t2;
int b = ans[i - 1] - t2;
if(t1 == abs(ans[i - 1] - ans[i - 2])) {
if(a >= std::min(ans[i - 1], ans[i - 2]) && a <= std::max(ans[i - 1], ans[i - 2])) ans[i] = a;
else ans[i] = b;
}
else if(t1 == t2) {
if(ans[i - 1] > ans[i - 2]) ans[i] = b;
else ans[i] - a;
}
else {
if(ans[i - 1] > ans[i - 2]) ans[i] = a;
else ans[i] = b;
}
}
int min = 0x7fffffff;
for(int i = 0; i < N; i++) min = std::min(min, ans[i]);
for(int i = 0; i < N; i++) ans[i] -= min;
int pos0, posn;
for(int i = 0; i < N; i++) {
if(ans[i] == 0) pos0 = i;
if(ans[i] == N - 1) posn = i;
}
if(pos0 > posn) for(int i = 0; i < N; i++) ans[i] = N - 1 - ans[i];
}
2019.2.14 考试T3 交互题的更多相关文章
- 2019.3.14解题报告&补题报告
A题 题意: 输入r, c,代表r*c的矩阵,接下来一行,是r个数,代表每一行里最大的数:接下来一行,是c个数,代表每一列中的最大数.求所给数据是否冲突. 思路:判断r个数中最大数maxr和c个数中最 ...
- 2019.2.25考试T3, 离线+线段树
\(\color{#0066ff}{题解}\) #include<bits/stdc++.h> #define LL long long LL in() { char ch; LL x = ...
- 2019.2.14 考试T1 FFT
\(\color{#0066ff}{ 题目描述 }\) 衡水二中的机房里经常有人莫名其妙地犇雷,leizi很生气,决定要找出那个犇雷的人 机房有n个人,每个人都认为机房里有两个人可能会犇雷,其中第i个 ...
- 2019.3.18考试&2019.3.19考试&2019.3.21考试
2019.3.18 C O D E T1 树上直接贪心,环上for一遍贪心 哇说的简单,码了将近一下午终于码出来了 感觉自己码力/写题策略太糟糕了,先是搞了一个细节太多的写法最后不得不弃疗了,然后第二 ...
- 每日一练ACM 2019.04.14
2019.4.14 第1001题:Sum Problem Problem DescriptionHey, welcome to HDOJ(Hangzhou Dianzi University Onli ...
- Codeforces Round #551 (Div. 2) E. Serval and Snake (交互题)
人生第一次交互题ac! 其实比较水 容易发现如果查询的矩阵里面包含一个端点,得到的值是奇数:否则是偶数. 所以只要花2*n次查询每一行和每一列,找出其中查询答案为奇数的行和列,就表示这一行有一个端点. ...
- E. XOR Guessing 交互题 Educational Codeforces Round 71 (Rated for Div. 2)
E. XOR Guessing 交互题. 因为这个数最多只有14位 0~13,所以我们可以先处理后面7位,然后再处理后面7位. 因为异或的性质,如果一个数和0异或,那么就等于本身. 所以我们第一次异或 ...
- Codeforces Round #812 (Div. 2) D. Tournament Countdown(交互题)
记录一下第一次写交互题 题目大意:一共有1<<n个人参加一场竞标赛,需要你通过比较两人的胜场来判断谁晋级,最终获得第一名 最多1/3*2^(n+1)次询问,每次询问query(a,b),如 ...
- 交互题[CF1103B Game with modulo、CF1019B The hat、CF896B Ithea Plays With Chtholly]
交互题就是程序与电脑代码的交互. 比如没有主函数的程序,而spj则给你一段主函,就变成了一个整体函数. 还有一种就是程序和spj之间有互动,这个用到fflush(stdout);这个函数就可以实现交互 ...
随机推荐
- 自定义ASP.NET MVC Html辅助方法
在ASP.NET MVC中,Html辅助方法给我们程序员带来很多方便,其重要性也就不言自明.有时候,我们不想重复地写一些HTML代码,或者MS没有提供我们想要的那个HTML标签的Html辅助方法,那么 ...
- highcharts图表显示鼠标选择的Y轴提示线
tooltip: { shared: true, crosshairs: [true, false] },
- java selenium webdriver第一讲 seleniumIDE
Selenium是ThoughtWorks公司,一个名为Jason Huggins的测试为了减少手工测试的工作量,自己实现的一套基于Javascript语言的代码库 使用这套库可以进行页面的交互操作, ...
- leetcode645
vector<int> findErrorNums(vector<int>& nums) { ; int S[N]; int n = nums.size(); ; i ...
- C语言学习笔记--指针概念
指针也是一种变量,占有内存空间,用来保存内存地址,在32位系统中指针的占用的内存大小为4个字节 1.*号的意义 (1)在指针声明时,*号表示所声明的变量为指针 (2)在指针使用时,*号表示取指针所指向 ...
- 浅谈Android四大组建之一Service---Service与Activity的绑定
从上一篇文章我们学会了如何创建Service,我们通过监听一个按钮,然后再按钮里面通过意图来启动Service.但是我们有没有发现,启动服务以后,Activity和Service之间的联系好像就断开了 ...
- 【android】关于自己实现adapter后gridview中item无法被选中的解决方法
有时候,自己继承实现了baseadapter将其赋给gridview之后,gridview会十分奇怪的无法选中内部的item. 经过仔细研究,我发现是在继承的时候多复写了几个方法,解决方法就是,只保留 ...
- java中的字符,字节和编码
1. 编码问题的由来,相关概念的理解 1.1 字符与编码的发展 从计算机对多国语言的支持角度看,大致可以分为三个阶段: 系统内码 说明 系统 阶段一 ASCII 计算机刚开始只支持英语,其它语言不 ...
- solr replication原理探究
原文出自:http://sbp810050504.blog.51cto.com/2799422/1423199 无论是垂直搜索,还是通用搜索引擎,对外提供搜索服务其压力都比较大,经常有垂直电商在做活动 ...
- Ros学习——C++发布器publisher和订阅器subscriber
1.编写发布器 初始化 ROS 系统 在 ROS 网络内广播我们将要在 chatter 话题上发布 std_msgs/String 类型的消息 以每秒 10 次的频率在 chatter 上发布消息 在 ...