#P9332. [JOISC 2023 Day2] Belt Conveyor(交互,无法评测)
[JOISC 2023 Day2] Belt Conveyor(交互,无法评测)
题目背景
这是一道交互题。
由于技术原因,本题暂不支持提交与评测。
如果您能够提供官方数据对应的 grader,请与 @RSY 联系。
题目描述
【题目描述】
In the factory of JOI Co., Ltd., there are tables, numbered from to . In the factory, there are belt conveyors, numbered from to . The belt conveyor connects the table and the table . It transports products from one table to the other table. However, we cannot see the direction of transportation. If we ignore the directions of the belt conveyors, every pair of tables is connected by a number of belt conveyors.
IOI-kun is the director of the factory. Since he forgets the direction of transportation of every belt conveyor, he will perform the following sequential operations several times.
- He chooses a number of belt conveyors, and reverses the directions of transportation of the chosen belt conveyors.
- He chooses a number of tables, and puts a product on each chosen table.
- For every table where a product is put, one of the following happens simultaneously.
- If there is no belt conveyor transporting products from it, nothing happens.
- If there are belt conveyors transporting products from it, the product on the table is transported by one of such belt conveyors. The product stops at the destination of the belt conveyor. The product will not move anymore.
- IOI-kun confirms whether there are one or more products on each table. If there are products on a table, IOI-kun takes all of them.
- For every belt conveyor whose direction is reversed in the operation 1., IOI-kun reverts its direction. Its direction becomes the original direction.
IOI-kun wants to specify the original direction of every belt conveyor by performing the above sequential operations at most times.
Write a program which, given information of the tables connected by the belt conveyors, implements IOI-kun’s strategy to specify the original direction of every belt conveyor by performing the above sequential operations at most times.
【实现细节】
You need to submit one file.
The file is conveyor.cpp
. It should implement the following function. The program should include conveyor.h
using the preprocessing directive #include
.
In conveyor.cpp
, the following function should be implemented.
void Solve(int N, std::vector<int> A, std::vector<int> B)
This function is called only once for each test case.
- The parameter
N
is the number of tables . - The parameters
A,B
are arrays of length , describing the tables connected by the belt conveyors.
Your program can call the following function.
std::vector<int> Query(std::vector<int> x, std::vector<int> y)
Using this function, IOI-kun performs the operations in the factory.
- The parameter
x
is an array of length . For , IOI-kun reverses the direction of the belt conveyori
ifx[i] = 1
, and does not reverses the direction of the belt conveyori
ifx[i] = 0
. - The parameter
y
is an array of length $$. For , IOI-kun puts a product on the tablej
ify[j] = 1
, and does not put a product on the tablej
ify[j] = 0
. - Let
z
be the return value of this function. It is an array of length . For , there are one or more products on the tablej
ifz[j] = 1
, and there is no product on the tablej
ifz[j] = 0
. - The length of the array
x
should be equal to . If this condition is not satisfied, your program is judged asWrong Answer [1]
. - Every element of the array
x
should be0
or1
. If this condition is not satisfied, your program is judged asWrong Answer [2]
. - The length of the array
y
should be equal to . If this condition is not satisfied, your program is judged asWrong Answer [3]
. - Every element of the array
y
should be0
or1
. If this condition is not satisfied, your program is judged asWrong Answer [4]
. - The function Query should not be called more than times. If it is called more than times, your program is judged as
Wrong Answer [5]
.
void Answer(std::vector<int> a)
Using this function, IOI-kun reports the original direction of each belt conveyor.
- The parameter
a
is an array of length . For , the belt conveyori
transports products from to ifa[i] = 0
, and it transports products from to ifa[i] = 1
. - The length of the array
a
should be equal to . If this condition is not satisfied, your program is judged asWrong Answer [6]
. - Every element of the array
a
should be0
or1
. If this condition is not satisfied, your program is judged asWrong Answer [7]
. - If IOI-kun reports wrong direction of a belt conveyor, your program is judged as
Wrong Answer [8]
. - The function
Answer
should be called exactly once. If the functionAnswer
is called more than once, your program is judged asWrong Answer [9]
. When the functionSolve
terminates, if the functionAnswer
is not called, your program is judged asWrong Answer [10]
.
Important Notices
- Your program can implement other functions for internal use, or use global variables.
- Your program must not use the standard input and the standard output. Your program must not communicate with other files by any methods. However, your program may output debugging information to the standard error.
【评测方式】
You can download an archive file from the contest webpage which contains the sample grader to test your program. The archive file also contains a sample source file of your program.
The sample grader is the file grader.cpp
. In order to test your program, put grader.cpp
, conveyor.cpp
, conveyor.h
in the same directory, and run the following command to compile your programs. Instead, you may run compile.sh
contained in the archive file.
g++ -std=gnu++17 -O2 -o grader grader.cpp conveyor.cpp
When the compilation succeeds, the executable file grader
is generated.
Note that the actual grader is different from the sample grader. The sample grader will be executed as a single process, which will read input data from the standard input and write the results to the standard output.
输入格式
The sample grader reads the following data from the standard input.
For , we have if the belt conveyor transports products from the table to the table . Otherwise, we have .
输出格式
The sample grader outputs the following information to the standard output (quotes for clarity).
- If your program is judged as correct, it reports the number of function calls to
Query
asAccepted: 22
. - If your program is judged as any type of Wrong Answer, the sample grader writes its type as
Wrong Answer [4]
.
If your program satisfies the conditions of several types of Wrong Answer, the sample grader reports only one of them.
In sample grader, among the belt conveyors transporting products from the table where a product is put, the belt conveyor transporting the product is chosen uniformly and randomly determined by pseudorandom numbers whose results do not change for different executions. In order to change the seed of pseudorandom numbers, run the sample grader with the first integer argument as follows.
./grader 2023
提示
【评测程序示例】
Here is a sample input for the sample grader and corresponding function calls.
Sample Input 1:
3
0 2
2 1
1 0
Function Calls | Return Values | |
---|---|---|
Solve(3, [0, 2], [2, 1]) |
||
Query([0, 0], [0, 0, 1]) |
[1, 0, 0] |
|
Query([1, 0], [1, 0, 1]) |
[0, 1, 1] |
|
Query([1, 1], [0, 0, 1]) |
[0, 0, 1] |
|
Query([0, 1], [1, 1, 1]) |
[1, 0, 1] |
|
Answer([1, 0]) |
For the first function call to Query
, another possible return value is [0, 1, 0]
other than [1, 0, 0]
.
For the second function call to Query
, the product on the table is transported to the table by passing through the belt conveyor , and stops there. Note that this product will not be transported to the table by passing through the belt conveyor .
Note that this sample input does not satisfy the constraints of any subtask.
Among the files which can be obtained from the contest webpage, sample-02.txt
satisfies the constraints of Subtask , and sample-03.txt
satisfies the constraints of Subtask .
Notices for Grading
For some of the test cases, the actual grader is adaptive. This means the grader does not have a fixed answer in the beginning, and responds according to previous function calls to Query. It is guaranteed that there is at least one answer which does not contradict all the responses of the the grader.
【数据范围】
对于所有测试数据,满足 ,保证忽略所有传送带的方向后所有机器连通,保证所有输入均为整数。
子任务编号 | 分值 | 特殊性质 | |
---|---|---|---|
无 | |||
, | |||
无 |