Préparation Au Concours ACM - TP 1: Christoph Dürr Jill-Jênn Vie September 19, 2014

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

Prparation au concours ACM TP 1

Christoph Drr Jill-Jnn Vie


September 19, 2014

Problems
All written contest materials will be in English.
Solutions to problems submitted for judging are called runs. Each run is judged as accepted
or rejected, and the team is notified of the results. Rejected runs will be marked as follows:
Compilation Error
Wrong Answer
Time Limit Exceeded
Presentation Error (lack of newline, extra spaces, etc.)
Runtime Error (most possibly a segmentation fault)

Scoring
Teams will be ranked by number of solved problems. In case of a tie, teams with less total
submission time are ranked first. For each solved problem, the time (in minutes) since contest
start will be added to the teams total time. For each wrong submission prior to the successful
one, 20 penalty minutes are added.

Material
Each team will be permitted to provide a PDF of up to 25 pages of notes within the limits
described during Team Certification. Three copies will be printed and placed at the teams
workstation for use during the World Finals.
Each team member may bring one printed, unannotated natural language dictionary. You
may bring mascots such as stuffed toy animals or party hats.

Computer
The keyboards will have Portuguese layout, but teams may bring their own USB-keyboard.
The command line for compiling used in the automated judge system is the following:
g++ -w -O3 -pipe $SOURCE

Links
You need to create an account on http://uva.onlinejudge.org to submit your codes.
For a few problems, you can get the output of any input on uvatoolkit.com.

1
Problem A Your Favorite Number Problem A
Write a program that prints your favorite (integer) number. It can be any number: your
age, the problems your team solved at UVa Online Judge, your TopCoder score, etc. Just print
the one you like the most.

Input
There is no input for this problem.

Output
The program must write to the standard output your favorite number.

Sample Input 1
Sample Output 2
42

Sample Input 1
Sample Output 2
168

2
Problem B Mean Value Problem B

Write a program that computes the mean value of a list of integers.

Input
An integer N , followed by a line containing N integers.

Output
The mean value of these N integers. Write out the result to two decimal places.

Sample Input
3
2 1 1

Sample Output
1.33

3
Problem C Find the Twin Problem C

You are given a list of words. Find out if theres a double.

Input
An integer T , followed by T cases of the following form:

An integer N ;

On the next N lines, a word.

Output
For each instance you must output one line of the following form:

Case #d: ANSWER

Where d stands for the instance number (starting from 1) and ANSWER is the lowest double
in lexicographical order if it exists, None otherwise.

Sample Input
3
1
Alice
2
Bob
Bob
3
Charles
Damien
Etienne
4
Frederic
Fanja
Fanja
Frederic

Sample Output
Case #1: None
Case #2: Bob
Case #3: None
Case #4: Fanja

4
Problem D Pascals Triangle of Death Problem D

UVa 485

In this problem, you are asked to generate Pascals Triangle. Pascals Triangle is useful
in many areas from probability to polynomials to programming contests. It is a triangle of
integers with 1 on top and down the sides. Any number in the interior equals the sum of the
two numbers above it. For example, here are the first 5 rows of the triangle.

1
1 1
1 2 1
1 3 3 1
1 4 6 4 1

In Pascals Triangle of Death, you are to generate a left justified Pascals Triangle. When
any number in the triangle is exceeds or equals 1060 , your program should finish printing the
current row and exit. The output should have each row of the triangle on a separate line with
one space between each element.
The final element of each line should be directly followed by a newline. There is no space
after the last number on each line.

Sample Input
There is no input for this problem.

Sample Output
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
.
.
.

etc.

5
Problem E Minesweeper Problem E

UVa 10189

The Problem
Have you ever played Minesweeper? Its a cute little game which comes within a certain
Operating System which name we cant really remember. Well, the goal of the game is to find
where are all the mines within a M N field. To help you, the game shows a number in a
square which tells you how many mines there are adjacent to that square. For instance, suppose
the following 4 4 field with 2 mines (which are represented by an * character):

*...
....
.*..
....

If we would represent the same field placing the hint numbers described above, we would
end up with:

*100
2210
1*10
1110

As you may have already noticed, each square may have at most 8 adjacent squares.

The Input
The input will consist of an arbitrary number of fields. The first line of each field contains two
integers n and m (0 < n, m 6 100) which stands for the number of lines and columns of the
field respectively. The next n lines contain exactly m characters and represent the field. Each
safe square is represented by an "." character (without the quotes) and each mine square is
represented by an "*" character (also without the quotes). The first field line where n = m = 0
represents the end of input and should not be processed.

The Output
For each field, you must print the following message in a line alone:

Field #x:

Where x stands for the number of the field (starting from 1). The next n lines should
contain the field with the "." characters replaced by the number of adjacent mines to that
square. There must be an empty line between field outputs.

6
Problem E Minesweeper Problem E

Sample Input
4 4
*...
....
.*..
....
3 5
**...
.....
.*...
0 0

Sample Output
Field #1:
*100
2210
1*10
1110

Field #2:
**100
33200
1*100

7
Problem F Power Strings Problem F

UVa 10298

Given two strings a and b we define a b to be their concatenation. For example, if a =


abc and b = def then a b = abcdef . If we think of concatenation as multiplication,
exponentiation by a non-negative integer is defined in the normal way: a0 = (the empty
string) and an+1 = a (an ). Each test case is a line of input representing s, a string of printable
characters. For each s you should print the largest n such that s = an for some string a. The
length of s will be at least 1 and will not exceed 1 million characters. A line containing a period
follows the last test case.

Sample Input
abcd
aaaa
ababab
.

Output for Sample Input


1
4
3

8
Problem G LCM Pair Sum Problem G

UVa 12546 (SWERC 2012)

One of your friends desperately needs your help. He is working with a secret agency and
doing some encoding stuffs. As the mission is confidential he does not tell you much about
that, he just want you to help him with a special property of a number. This property can be
expressed as a function f (n) for a positive integer n. It is defined as:
X
f (n) = (p + q)
16p6q6n
lcm(p,q)=n

In other words, he needs the sum of all possible pairs whose least common multiple is n.
(The least common multiple (LCM) of two numbers p and q is the lowest positive integer
which can be perfectly divided by both p and q). For example, there are 5 different pairs
having their LCM equal to 6 as (1, 6), (2, 6), (2, 3), (3, 6), (6, 6). So f (6) is calculated as f (6) =
(1 + 6) + (2 + 6) + (2 + 3) + (3 + 6) + (6 + 6) = 7 + 8 + 5 + 9 + 12 = 41. Your friend knows
you are good at solving this kind of problems, so he asked you to lend a hand. He also does
not want to disturb you much, so to assist you he has factorized the number. He thinks it may
help you.

Input
The first line of input will contain the number of test cases T (T 6 500). After that there will
be T test cases. Each of the test cases will start with a positive number C (C 6 15) denoting
the number of prime factors of n. Then there will be C lines each containing two numbers
Pi and ai denoting the prime factor and its power (Pi is a prime between 2 and 1000) and
(1 6 ai 6 50). All the primes for an input case will be distinct.

Output
For each of the test cases produce one line of output denoting the case number and f (n) modulo
1000000007. See the output for sample input for exact formatting.

Sample Input 1
3
2
2 1
3 1
2
2 2
3 1
1
5 1

Sample Output
Case 1: 41
Case 2: 117
Case 3: 16

You might also like