Α ribbon is N cm long and every centimeter has a color of K different colors, numbered from 1 to K.
(1 ≤ Ν ≤ 1.000.000) (1 ≤ Κ ≤ 100.000)
In the above example, the ribbon has length N = 10 cm and there are K = 3 colors: yellow (1), orange (2) and green (3).
We want to find the smallest possible piece of ribbon it contains all the colours. If there is no such piece, then the number 0 (zero) must be written on the output. The input data is read from a .txt file.
Examples:
C
$ ./colors c1.txt
4
Standard ML
- colors "c2.txt";
10
val it = () : unit
Prolog
?- colors('c3.txt', Answer).
Answer = 0 ;
false.
A two-dimensional map is given, consisting of N x M squares (1 ≤ N, M ≤ 1000). Each square of the map contains one of the following symbols:
- "A": Cat's initial position.
- "W": The square contains a broken water pipe.
- "." (dot): The square is initially blank.
- "X" (obstacle): Neither cat nor the water can go to this square.
At any given time, the water coming out of the broken pipes spreads to adjacent squares (left, right, top and bottom), if these are not obstacles and the map is slowly flooding. Water moves at a rate of one square per unit time and also the cat can move to her neighboring squares, with rate one square per unit time.
We want to find
- what is the latest time we can save the cat and
- in which square of the map will we put her to save her.
The answer to the second question is a string that describes the sequence of moves that the cat will make to be in the square from which we will save her. Moves are represented by the symbols:
- "R": Move one square to the right on the map.
- "L": Move one square to the left on the map.
- "U": Move one square up on the map.
- "D": Move one square down the map.
If this sequence is empty, then in the second line the word "stay" must be printed. If the cat is safe and we can save it at any time, in the first line the word "infinity" must be printed. If there are many different solutions, then we choose a sequence of movements that leads to the square with the lexicographically smallest coordinates (first row and then column) and if there are many sequences of movements leading to this square, then we select the smallest number of moves and (among equals) the lexicographically smaller.
The input of the program is read from a file consisting of N lines, each of which contains M symbols. This file represents the map.
Examples:
C++
$ ./savethecat a1.txt
infinity
stay
Python
$ python3 savethecat.py a2.txt
5
RDDLL
Java
$ java SaveTheCat a3.txt
15
DDDRRRURR
In a lottery, N are the lottery tickets sold, each of which is a number Xi consisting of exactly K decimal digitis. A lucky number Y is drawn. Based on this number, each lottery ticket wins a sum of money as follows:
If the M last digits of the lottery ticket Xi are the same as the M last digits of the lucky number Y, then the ticket wins 2Μ−1 euro.
A list of Q possible lucky numbers Yi is given. For each such lucky number Yi, we must find how many tickets win some non-zero amount (i.e. how many tickets have one or more common ending digits with the lucky number Yi) and which is the total amount that all lotteries win.
Examples:
Standard ML
- lottery "t1.txt";
1 15
val it = () : unit
Prolog
?- lottery('t2.txt', L).
L = [[2, 16], [0, 0], [3, 7]].
Collaborator: Dimitris Kranias