Всем привет.
Контест закончен, а обсуждения пока нет. Я же с интересом жду разморозки результатов http://opentrains.snarknews.info/~ejudge/res/res10355
Как там в Новосибирске? Какие у участников впечатления от онсайта?
№ | Пользователь | Рейтинг |
---|---|---|
1 | tourist | 4009 |
2 | jiangly | 3823 |
3 | Benq | 3738 |
4 | Radewoosh | 3633 |
5 | jqdai0815 | 3620 |
6 | orzdevinwang | 3529 |
7 | ecnerwala | 3446 |
8 | Um_nik | 3396 |
9 | ksun48 | 3390 |
10 | gamegame | 3386 |
Страны | Города | Организации | Всё → |
№ | Пользователь | Вклад |
---|---|---|
1 | cry | 167 |
2 | maomao90 | 163 |
2 | Um_nik | 163 |
4 | atcoder_official | 161 |
5 | adamant | 159 |
6 | -is-this-fft- | 158 |
7 | awoo | 157 |
8 | TheScrasse | 154 |
9 | nor | 153 |
9 | Dominater069 | 153 |
Всем привет.
Контест закончен, а обсуждения пока нет. Я же с интересом жду разморозки результатов http://opentrains.snarknews.info/~ejudge/res/res10355
Как там в Новосибирске? Какие у участников впечатления от онсайта?
Название |
---|
Why so strange restrictions on a^2+b^2 ?
Restrictions for a and b allow to use integer coefficients when line formed by any two points from square where triangle can be located.
Upper bound for a2 + b2 is redundant and should be set to maximum a2 + b2 value. Unfortunately it was set twice smaller and this mistake was found too late. Nevertheless it's easy to divide a, b and c by 2 and satisfy to restrictions without double precision loss.
1) Why it is not PE? 2) Why did not increase restriction twice more during the contest?
А как 10-ю пихать?
У нас зашло после отсечения "если до клетки в принципе не дойти, то нам пофиг есть там стена или нет". Так склеивается сильно больше состояний.
Спасибо, до этого отсечения не додумались, с ним довольно просто запихнулось за 7.5.
На самом деле ключевыми были две оптимизации. Первая — кешировать состояния, ведь на старте может быть много повторов для большинства тестов, второе — исключать из битовой маски уничтоженных стен те, которые уже не могут быть достигнуты из текущего состояния ни при каком возможном сценарии. В одном из авторских решений по таким состояниям делается обычный BFS. Переходы между состояниями рекомендуется делать за O(1), особенно это касается выстрелов. Для каждого положения танка и состояния (целых и разрушенных) клеток в той же строке и том же столбце можно заранее определить все возможные переходы. После чего доставать их, например, из хеш-таблицы за O(1). Можно воспользоваться и другими способами.
Это я не умею писать или идея в 5 неверна? Переберем кол-во голосующих за нашего кандидата(х), после чего построим сеть, где через остальных проходит х-1 потока, через нашего кандидата и вершину прогула inf. После того как посчитаем поток, жадно переманиваем к нашему кандидату недостающих голосующих. Выбираем наилучший ответ. Wa9
Идея правильная, я таким же способом сдал. Тоже было WA 9, там нужно было long long использовать.
Мы перебирали x, через нашего в сток идет x, через остальных, кроме 'не прийти', идет x-1 в некую вершину Z, из 'не прийти' в Z идет инф, из Z в сток идет N-x. И ничего переманивать не нужно
можно вместо жадности в конце, поставить x пропускной способности и -INF стоимости
How to solve 11?
For each suffix compute the value (as a decimal number) mod P. Let ai be the value corresponding to the suffix starting at i.
Then, for a fixed j, the value of the substring [i..j) only depends on ai. Now it's easy to get an O(nlogn) solution for each query.
In fact you can get O(NT) solution (without logarithm) by using hash table.
Just make sure you do O(N) insertions total instead of O(NT), otherwise you'll get TL unless you write a hand-optimized hash table.
Задача11 у дивизионов совпадала? Если да, то сдавали ли в первом дивизионе O(ntlogn)? Во втором дивизионе в этой задаче стоял ТЛ 1 секунда и даже вполне оптимальное решение, где logn это бинарный поиск по массиву не проходит.
UPD: У единственной сдавшей команды в div2 было +27, а стало +18. А так же был расширен ТЛ до 2-ух секунд.
unordered_map + reserve заходит за 0.7.
Наш исходник: https://gist.github.com/yarrr-ru/61da2acffff64b1a35117938fff83564
Спасибо за этого!
На онсайте, кажется, был tl 3 секунды. (Но тут нужно не забывать, что открытый кубок и онсайт, насколько я понимаю, тестируется на разных серверах). Вроде бы (судя по таблице и со слов участников), у некоторых команд на онсайте тоже были проблемы со временем в этой задаче.
Ну... TL в 1 секунду — это совсем не то, о чём шла речь в Новосибирске. Авторские решения работают от 0.5 до 1 сек, при таких порядках было решено выставить достаточно лояльный TL в 3 секунды. Однако, написав первое попавшееся решение на unordered_map, участники не только не хотели реструктуризировать само решение, но и не хотели отказываться от STL-евского unordered_map. Видимо, нынче самописные hash-таблицы уже не в моде.
Почему во втором диве поставили такой TL остается только догадываться. Думаю, что это — ошибка жюри. Конечно же, как автор задачи, я бы ни за что не поддержал такой строгий TL к этой задаче. Более того, для второго дивизиона можно было бы еще и ослабить его, чтобы решения с использованием логарифмических структур успевали в ограничение по времени.
Действительно, был сбой при переносе на ejudge. После замены TL на 2 секунды (такой же, как на Яндекс.Контесте и соответствующий инструкциям по выставлению TL; сервера в дивизионах более-менее одинаковы с точки зрения TL, в то время как сервер на онсайте примерно на 40% медленнее) все попытки были пересужены и результаты не поменялись. После замены TL на 2.5 секунды с учётом пожеланий разработчика задачи Павла Хаустова у команды Mozyr CYF 1 задача прошла.
How to solve 5-th problem?
I think 5th is MCMF problem. You can fix number of people who votes for no one, and maximum votes that other candidates get. Then build network with this variables and run MCMF. But not sure about whether it fits in time limit or not. I didn't have time to code it at contest because of 11th problem time limit in DIV2 :) I hope someone who solved it will write more detailed solution.
I solved it with MCMF.
Let a be the exact number of votes that we want our winning candidate to receive. Construct a flow graph with source/sink, a node for each person that is voting (N nodes), and a node for each voting option (K + 1 nodes). We need the following edges:
It is clear that the minimum-cost flow here corresponds to the minimum cost required to have our candidate win with exactly a votes (the large negative cost from the source to our candidate forces any minimum-cost max flow to vote for our candidate a times). We can increment the cost of this flow by a·(negativecost) to get the exact cost, and look at the residual graph to reconstruct the solution. Finally, we can iterate a from 1 to N to get the optimal assignment.
One thing worth noting is that the function "cost to win with exactly a votes" (depending on a) is convex. This can be proved by taking optimal flows for a = x and for a = z, then observing that their convex combination with appropriate coefficients would be a valid flow in the graph for a = y (where x < y < z).
So you could optimize your solution by doing something like a ternary search over a.
А какие резы на онсайте? Может у кого есть скриншот или фото размороженные?
Закрытие олимпиады завтра, вряд ли монитор онсайта разморозят до него.
А, спасибо. Я думал в понедельник всем на учебу, поэтому закрывают в воскресенье :)
How to solve 10? It seems brute force is not too slow and only slight improvement is enough.
1) Brute first K moves.
2) After that you have state (X, Y, DestructedWalls). For optimizations purpose DestructedWalls can be 64 bit mask.
3) Clean up bits in DestructedWalls mask, if you can't visit some walls anymore with (n - K) moves (to reduce different masks count).
4) After that there are not so many different states. For each just brute remain (n - K) moves.
K ~= 23 - 24 works for us in upsolving.
In fact, there is no need to do any portion of brute force here.
You can run DP with states: (turns passed, robot position, 64-bit mask of destroyed walls), always storing the states only for a single current value of "turns passed". In each state store also its multiplicity (i.e. how many ways are there to get it). After modelling each turn, merge all equal states.
Now you have to add the "finish optimization". For each number of passed turns and robot position, precompute the set of cells you can theoretically move into regardless of whether any brick wall is destroyed or not. Then in the main DP you do bitwise AND between the mask of destroyed walls and mask of potentially visitable cells in future (i.e. you are forgetting about destroyed walls you can never bump into).
With such a solution, there is no need to tweak a special parameter K, and no need to write recursive search.
How to solve C and D?
Also, I was wondering if there is any clever solution for F. I solved it using Hopcroft's DFA minimization algorithm.
For F: take any remainder x modulo M. Now consider the chain of segments: [x, x], [b*x, b*(x+1)-1], [b*b*x, b*b*(x+1)-1], ... Find the first segment in this chain that contains 0 modulo M. The pair (k, (x*b**k) mod M) now uniquely defines state x, where k is the number of the segment (in other words, the size of the segment and its left boundary).
C: we will only use "is intersection empty" questions. First, find bounding box using binary searches by X and Y. At least one of its corners is a vertex of the triangle, we can check by truncating a small 0.5*0.5 triangle from the corner. Now we've found a vertex and a 90 degree angle containing everything. Now use two binary searches by angle to find rays containing two sides from that vertex. Finally, use binary searches with half-planes parallel to one side to find the vertex on the other side.
D: I find it really hard to explain, but the solution itself is really easy. First, the problem easily boils down to: you have N left ends, then N right ends of segments, connected somehow in pairs. Let's call two segments connected if they intersect, but not one lies inside another. Now we need to find connected components, check if each component is bipartite, and color with two colors if it is, all faster than N**2.
It turns out that because all left ends come before all right ends, the structure is really simple. Let's look at the left end corresponding to the first right end. All left ends after it intersect it, and thus must have the opposite color. Thus, their right ends must go in reverse order (to avoid intersections between them). Now let's consider the rightmost right end of those. All remaining uncolored right ends to the left of it, again, must have the first color, and so on.
Code for the coloring part:
In fact, we did not find this a simple solution. We used a more technical approach.
Renumber wires on the left to be [1..N] (and wires on the right accordingly). Then the indices of wires on the right form a permutation. It is easy to notice that we have to break this permutation into two increasing subsequences (one for inner wires, one for outer wires). For each element, we know the cost of including it into each subsequence.
This problem can be trivially solved by DP with O(N2) states. In fact, you can use only O(N) states looking like (size of prefix processed, which subsequence contains last processed element). To achieve this, you have to add whole increasing blocks to alternating subsequences, one block on each step of DP.
This DP takes O(N) memory, but O(N2) time. It can be optimized with RMQ structure to O(NlogN) time in a way similar to how classical "maximal increasing subsequence" is optimized with RMQ. In fact, it is also possible to optimize it to pure O(N) without any data structure by simply saving some minimums during long increasing runs. Of course, the details are rather nasty =)
Right, the two increasing subsequences paradigm also allows to explain my solution a bit easier: let's look at 1. All numbers to the left of it must go to the other subsequence, and thus be in increasing order. Let the last of them (right before 1) be X. Now all remaining numbers less than X must go to the same sequence as 1, and be in increasing order, and so on.
У меня одного opencup таблицы результатов не открываются уже давно? В том числе прикрепленная Майком.
Результаты онсайта. Таблички 2 тура не было, так что пока так.
https://cloud.mail.ru/public/69Rv/JzWJJQK8e
https://cloud.mail.ru/public/MySS/LQpe8ALbS
Размороженный рейтинг с онсайта здесь.
How one can solve 8?
Yes, I would like to know about solving this problem too. I got TL 16 because of usual tree structure (bad idea when tree looks like a line — so queries would be executed O(N)), but what is right solution?
What we need a data structure that allows to update numbers in a tree and to find the sum of numbers in a subtree. If we do a preorder traversal of the tree, then any subtree will correspond to a segment in that ordering. And a data structure that allows updating numbers and finding segment sums is a Fenwick tree.
Thank you for your answer, I thought about segment tree, but could not understand how to enumerate vertices (build segment tree)... It is not difficult for me when we build segment tree according to the array 1..N, but when we have tree with randomly enumeration in that problem — I don't know about representing.