Home Page | Web Board | Problems | Standing | Status | Statistics | Award Contest |
Contest - POJ Founder Monthly Contest – 2008.04.13
Start time: 2008-04-13 12:00:00 End time: 2008-04-13 17:00:00
Current System Time: 2025-01-24 16:43:48.980 Contest Status:
Ended
Problem ID | Title |
3577 Problem A | Global Positioning System |
3578 Problem B | Card Game |
3579 Problem C | Median |
3580 Problem D | SuperMemo |
3581 Problem E | Sequence |
3582 Problem F | Last Hit |
3583 Problem G | Text Message Formatting |
3584 Problem H | Small Polynomial Factorization |
[Standings] [Status] [Statistics]
Contest Report | |||||||||||||||||||||||||
Table of Contents
Problem A: Global Positioning SystemThe idea is to solve a equation having trigonometric functions. Suppose that t1=0 and let x2' = x2 - x1, y2' = y2 - y1, x3' = x3 - x1, y3' = y3 - y1, x' = x - x1, y' = y - y1. Then we have two equations : where by letting we obtain Problem B: Card GameIt is obvious that Jack will add m points to apo. Also it can be proven that if Joe can win p rounds he must have a strategy to achieve it using only the most powerful p cards. So the idea is bisecting p and testing whether it can be achieved. The testing can be solved by a greedy algorithm. Problem C: MedianAssume X1, X2, ... Xn is the non-descending permutation of the numbers. Consider the following table:
The rows are non-ascending from left to right and the columns are non-descending from top to bottom. Given a value, we can use the table to calculate how many differences are less than it. Problem D: SuperMemoThe trivial solution in O(mn) will apparently get TLE. We can use a balanced-tree, like Splay Tree, to maintain the sequence effectively. The relative sequence number is the keyword of each nodes in the tree. For example the sequence{29, 25, 30, 41, 56} can be represented as the following balanced-tree : (the number in blanks are their sequence index) 30(3) / \ 25(2) 56(5) / / 29(1) 41(4)Every tree node needs to record at least following information: int data ——the current data of this node int t ——the total number of tree nodes in this sub-tree int delta ——the common increasing value on each nodes in this sub-tree bool reverse ——whether the whole sub-tree needs to be reversed. Since then, we may maintain the every single operation in O(logn) in average time. For example, the "RESERVE x y" command, we can operate as follows: STEP1 : cut the tree into 3 sub-trees: T1(X-1 nodes), T2(Y-X+1 nodes), T3(n-Y nodes) STEP2 : change T2.reverse to !T2.reverse(reverse the sub-tree T2) STEP3 : merge the 3 sub-trees in turn. Problem E: SequenceAssume R is the reverse of the given sequence, then the first cutting position is where the smallest suffix of R starts which can be evaluated effectively by suffix array. The second cutting position can be obtained in a similar way. Problem F: Last HitIf neither hero can hit the creep before it dies, the answer is clearly "God". Apart from this situation, as the creep will counted for hero1 if their bullets hit the creep at the same time, hero1 will definitely win if t1 is not greater than t2, whatever their attacks are. If t1 is greater than t2, it can be proven that no one will attack (or their attacks will do no effect to the result) before the hp of the creep reaches max{a1+t1*v,a2+t2*v}, so all you need to do is to set the hp of the creep to max{a1+t1*v,a2+t2*v} (If the initial hp of the creep is bigger than max{a1+t1*v,a2+t2*v}) and simply calculate who will get the last hit of the creep. Problem G: Text Message FormattingThere multiple tricky cases which a solution has to take into consideration to be correct. They include
Problem H: Samll Polynomial FactorizationIf a reducible polynomial f(x) of order δ must have a irreducible factor g(x) of order not exceeding δ/2. We try to find g(x) by enumeration. Suppose we want to find a second-order g(x). We need three (x, g(x)) pairs to uniquely determine g(x). Observe that for any x such that f(x) ≠ 0, g(x) must be a divisor of f(x). This prompts us to find x1, x2, x3 such that f(x1), f(x2), f(x3) ≠ 0, enumerate y1, y2, y3 which are a divisor of f(x1), f(x2), f(x3) respectively, fit a g(x) through the points (x1, y1), (x2, y2), (x3, y3) and check whether it has integral coefficients and is indeed a factor of f(x). |
All Rights Reserved 2003-2013 Ying Fuchen,Xu Pengcheng,Xie Di
Any problem, Please Contact Administrator