Problem Set: The 33 ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

Download as pdf or txt
Download as pdf or txt
You are on page 1of 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

The 33rd ACM International Collegiate Programming


Contest Asia Regional Contest - Hefei

Problem Set

Hosted by University of Science and Technology of China


Nov. 16, 2008

This problem set contains 8 problems; 15 pages totally.

1 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

Problem A: A Simple Game


Alice and Bob are playing a simple game. They have N integer numbers and a target
number T in common. Either of them independently and randomly picks a number
from the N numbers. They win the game if the product of the two picked numbers is
strictly greater than the target number T. You are to calculate the probability that they
will win. Assume that each number is picked with the same probability.

Input
The input consists of multiple test cases. Each test case consists of two lines.
The first line contains two integers N ( 1 N 30,000 ) and T ( 10 9 T 10 9 ).

The second line contains N integers numbers that Alice and Bob have, each of which
will be between 30,000 and 30,000 , inclusive. The last test case is followed by a
line containing two zeros.

Output
For each test case, print a line containing the test case number (beginning with 1)
followed by the probability of which Alice and Bob will win the game. The
probability is printed as a fraction number formatted as " a / b ", where the greatest
common divisor of a and b must be 1.

Sample Input
20
2 -9
45
1 -4 3 -2
00

Sample Output
Case 1: 1/2
Case 2: 1/4

2 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

Problem B: Discrete Square Roots


A square root of a number x is a number r such that r 2 = x . A discrete square root of
a non-negative integer x is a non-negative integer r such that r 2 x mod N ,
0 r < N , where N is a specific positive integer and mod is the modulo operation.

It is well-known that any positive real number has exactly two square roots, but a
non-negative integer may have more than two discrete square roots. For example,
for N = 12 , 1 has four discrete square roots 1, 5, 7 and 11.
Your task is to find all discrete square roots of a given non-negative integer x. To
make it easier, a known square root r of x is also given to you.

Input
The input consists of multiple test cases. Each test case contains exactly one line,
which gives three integers x, N and r. ( 1 x < N , 2 N < 1,000,000,000 , 1 r < N ).
It is guaranteed that r is a discrete square root of x modulo N. The last test case is
followed by a line containing three zeros.

Output
For each test case, print a line containing the test case number (beginning with 1)
followed by a list of corresponding discrete square roots, in which all numbers are
sorted increasingly..

Sample Input
1 12 1
4 15 2
000

Sample Output
Case 1: 1 5 7 11
Case 2: 2 7 8 13

3 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

Problem C: Necklace
A necklace in an undirected graph is a sequence of cycles C1 , C 2 , ... , C k ( k 1 ),
satisfying the conditions below:
1. Any two cycles have no edges in common.
2. There is exactly one common vertex between two adjacent cycles Ci and C i +1
(1 i < k )
3. Any two non-adjacent cycles are vertex disjoint, i.e. no vertices in common.
Note that any vertex appears in a cycle at most once.
A necklace between two vertices S and T is a necklace C1 , C 2 ,..., C k such that S
belongs to C1 and T belongs to C k .
Given an undirected graph and two vertices S and T, you need find whether a necklace
between S and T exists.

Input
The input consists of multiple test cases. Each test case starts with a line containing
two integers N ( 2 N 10,000 ) and M ( 1 M 100,000 ), which are the number of
vertices and the number of edges in the undirected graph, respectively.
Each of the following M lines contains two integers A and B ( 1 A B N ), which
indicates an undirected edge between vertices A and B. Vertices are numbered from 1
to N.
The last line of each test case contains two integers S and T ( 1 S T N ).
The last test case is followed by a line containing two zeros.

Output
For each test case, print a line containing the test case number (beginning with 1)
followed by "YES", if the required necklace exists, otherwise "NO".

Sample Input
33
12
23
4 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

31
13
45
12
23
13
34
34
14
45
12
12
23
34
34
14
00

Sample Output
Case 1: YES
Case 2: YES
Case 3: NO

5 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

Problem D: Polynomial-time Reductions


In computational complexity theory, polynomial-time reduction is an important
concept.
If the existence of a polynomial-time algorithm for problem B implies that problem A
also has a polynomial-time algorithm, we say that problem A has a polynomial-time
reduction to problem B. The relation of reduction is transitive, i.e. if A has a reduction
to B and B has a reduction to C, then A has a reduction to C.
Theoretical computer science researchers have found hundreds of polynomial-time
reductions between problems, which build a large network of reductions in
computational complexity theory.
In this network, some reductions are explicitly presented and others exist implicitly.
For example, if the reductions from A to B and from B to C are explicitly presented
and the reduction from A to C is not explicitly presented, we say that the reduction
from A to C exists implicitly.
In fact, some reductions are not necessary to present explicitly in the network. For
example, if reductions from A to B and from B to C exist explicitly or implicitly in the
network, then the reduction from A to C is not necessary to present explicitly. By this
fact, it's possible to simplify the network of reductions.
Your task is just to simplify the network of reductions such that the number of
reductions explicitly presented in the simplified network is minimized and reduction
from problem A to problem B exists explicitly or implicitly in the simplified network
if and only if it exists in the original network explicitly or implicitly.

Input
The input consists of multiple test cases. Each test case starts with a line containing
two integers N and M ( 1 N 100 , 0 M 10000 ), which are the number of
problems and the number of explicitly presented reductions in the network. The
problems are numbered from 1 to N.
Each of the following M lines contains two integers A and B ( 1 A N , 1 B N ,
A B ), which means a polynomial-time reduction from problem A to problem B is
explicitly presented in the network. The last test case is followed by a line containing
two zeros.

6 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

Output
For each test case, print a line containing the test case number (beginning with 1)
followed by a integer which is the number of explicitly presented reductions in the
simplified network.

Sample Input
33
12
23
13
46
12
21
23
32
34
43
00

Sample Output
Case 1: 2
Case 2: 4

7 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

Problem E: Post Offices


There is a straight highway with N villages alongside it. The villages are numbered
from 1 to N in one direction of the highway.
The government is planning to build at most M post offices in some of the villages.
The amount of money to build a post office in the ith village is C i and a post
office in the ith village can serve all villages within Ri kilometers to the left and
right of it.
If the ith village has no post office built and no post offices in other villages can
serve it, the government has to compensate the villagers Pi money. Here Ci , Ri and

Pi are all non-negative integers. You are to help the government to find a strategy
with minimum cost.

Input
The input consists of multiple test cases. Each test case starts with a line containing
two integers N ( 2 N 10000 ) and M ( 1 M N , M 100 ).
The following line contains N 1 positive integers, which are the distances between
village 1 and villages 2 ,3,...,N in kilometers. The distances will be not greater than
1,000,000,000 and strictly increasing.
The third line of each test case contains N integers C1 , C 2 , ... , C N , each of which
is between 0 and 10,000, inclusive.
The fourth line of each test case contains N integers R1 , R2 , ... , R N , each of which
is between 0 and 1,000,000,000, inclusive.
The last line of each test case contains N integers P1 , P2 , ... , PN , each of which is
between 0 and 10,000, inclusive.
The last test case is followed by a line containing one zero.

Output
For each test case, print a line containing the test case number( beginning with 1)
8 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

followed by the minimum amount of money the government has to pay.

Sample Input
32
12
232
110
10 20 30
32
10 20
100 2 300
567
10 100 400
00

Sample Output
Case 1: 3
Case 2: 312

9 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

Problem F: Programmers
In some international companies (e.g. SUN and IBM), programmers can work at
home via internet.
Each programmer has his/her own work time interval. For example, Tom always
works from 11:15 to 19:34 every day and Alice works from 22:14 to 05:13 of the
morrow. Note that the time intervals may span two days, but the lengths of them will
be strictly less than 24 hours.
Two programmers can talk with each other by instant messenger software if and only
if their work time intervals overlap. Note that only having common beginning or
ending point doesn't work. For example, the interval (11:15, 19:34) overlaps with the
interval (19:33, 20:10), but (11:15, 19:34) doesn't overlap with (19:34, 11:15).
Now a big project needs as many programmers as possible such that any two of them
can talk with each other at some time in their work time intervals.
You are to find the maximum number of programmers who can participate in the
project.

Input
The input consists of multiple test cases. Each test case starts with a line containing
one integers N ( 1 N 1000 ), which is the number of programmers in the company.
Each of the following N lines gives a work time interval of a programmer in the
format of "ab:cd-ef:gh", where "ab:cd" and "ef:gh" are beginning time and ending
time written in the 24-hour notation. You can assume that the input times are legal
and the beginning and ending times are different.
The last test case is followed by a line containing one zero.

Output
For each test case, print a line containing the test case number (beginning with 1)
followed by a integer which is the maximum number of programmer who can
participate in the project.

Sample Input
3
21:59-00:43
00:42-13:03
12:00-22:00
3
21:59-21:58
10 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

21:58-21:59
21:58-05:08
0

Sample Output
Case 1: 3
Case 2: 2

11 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

Problem G: Rational Number Approximation


It is well-known that any rational number can be represented as a fraction a / b .
Sometimes the denominator b is a very large integer. Mathematicians hate to write
down a tedious long integer, so they usually use two fractions a1 / b1 and a 2 / b2 to
approximate the rational number a / b such that a1 / b1 a / b a 2 / b2 and the
denominators b1 and b2 are not greater than a given integer N. You are to help
mathematicians to find such a1 / b1 and a 2 / b2 so that the difference between
a 2 / b2 and a1 / b1 is as small as possible.

Input
The input consists of multiple test cases.
Each test case contains exactly one line, which gives three integers a, b and N.
( 0 a < 2 10 9 , a < b 2 10 9 , 1 N < 2 10 9 ).
The last test case is followed by a line containing three zeros.

Output
For each test case, print a line containing the test case number (beginning with 1)
followed by the two fractions a1 / b1 and a 2 / b2 formatted as the sample output.
The greatest common divisor of a1 and b1 must be 1, so does that of a 2 and b2 .

Sample Input
131
132
000

12 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

Sample Output
Case 1: 0/1 1/1
Case 2: 0/1 1/2

13 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

Problem H: Triangles
There are some points in the 2-dimensional plane. Each point is colored red, green or
blue. No three points are collinear. Any triple of blue points can form a triangle,
which is called a blue triangle. A blue triangle is called red-blue triangle if there are
more red points than green points in it, or green-blue triangle if there are more green
points than red points in it.
You are to count the numbers of red-blue triangles and green-blue triangles.

Input
The input consists of multiple test cases. Each test case starts with a line containing
three integers R, G and B ( 0 R, G, B 100 ), which are the numbers of red, green
and blue points, respectively.
Each of the following R lines contains two integers x and y ( 0 x, y 10000 ), which
gives the coordinate of a red points.
The following G lines and B lines give the coordinates of all green points and blue
points in the same manner, respectively.
The last test case is followed by a line containing three -1.

Output
For each test case, print a line containing the test case number (beginning with 1)
followed by two integers, which are the numbers of red-blue triangles and green-blue
triangles.

Sample Input
113
11
23
00
03
30
111
00
11
23
-1 -1 -1
14 / 15

The 33rd ACM International Collegiate Programming Contest Asia Regional Contest - Hefei

Sample Output
Case 1: 1 0
Case 2: 0 0

15 / 15

You might also like