Всем доброго времени суток)
Рады приветствовать вас на очередном раунде Codeforces #141 для участников Div. 2. Как обычно, остальные могут поучаствовать в нем вне конкурса.
Задачи для вас были подготовлены группой авторов в составе: Павел Холкин (HolkinPV), Иван Фефер (Fefer_Ivan), Игорь Кудряшов (Igor_Kudryashov) и Геральд Агапов (Gerald). Как обычно, хочется поблагодарить Михаила Мирзаянова (MikeMirzayanov) за прекрасную систему Codeforces и Марию Белову (Delinur), которая переводила условия.
Распределение баллов по задачам стандартное.
Всем участникам соревнования мы желаем удачи, успешных взломов и высокого рейтинга!
UPD: контест завершился, надеемся вам понравилось) Поздравляем победителей:
1) AntiFate
2) alicechennan
4) Fride
5) bla_bla_bla
UPD2: разбор задач опубликован, его можно найти здесь
Какая будет разбалловка?
Все, вижу...
When you decide which type of score distribution to choose, what do you base your decision on?
already mentioned. "Score distribution is standard." that means in ascending order.
I think his Question ,why he choose standard and doesn't choose dynamic ? what's the decision based on ?
sorry for that. I am still learning english....
I am guessing it is based on how confident the authors are of the difficulty level of the problems. If they are very confident then standard score distribution otherwise dynamic.
Confident or not, they were wrong :)
Популярный будет контест — за 40 минут — x2122 зарегистрированных!
и необычный не одного полного решения задачи С в фпс и дельфи.:)
Ну так contest_id=228!!!
Всем счастья ^^
Всем лучи добра :D
Надеюсь задачи будут решаемы для меня ! Всем удачи)
Это невозможно...
Just Do It!
Немного надоели радостные посты о всеобщем счастье на контесте, созданные для прокачки вклада. Не по понятиям поступаете, господа.
20 деревьев отрезков авторское решение или мне надо отдохнуть? (Задача D) UPD Даже прошло...
У меня было 72 дерева Фенвика =) Почему бы и нет, теоретически должно проходить. Но я не успел =(
А как затолкать эти деревья в память? У меня решительно не лезли.
Примерно так:
Это если деревья Фенвика. Деревья отрезков так же проходят. Но там уже надо все ограничения ставить в упор.
Что-то типа
У меня упало при 30*4*10^5 интов О_о. Я определённо что-то делаю не так.
UPD. Epic Fail. Забыл отключить freopen("input.txt","r",stdin). Поэтому программа читала n = 0 и уходила в бесконечную рекурсию в попытке построить дерево на отрезке (0, n-1).
Ловкость рук и никакого мошенничества :)
UPD Люди не понимают иронии =(
Растолкуйте остолопке, отчего в задаче В div2 -1 -1 — это правильное решение, а 60 60 — нет? Ведь сдвиг и так и так получится 0.
Там по модулю не берут.
Если мы сдвинем нижний квадрат на -1 -1, то две единицы совместятся, и стоимость будет 1. При любом другом сдвиге стоимость будет 0.
Спасибо, разобралась!
В Е была 2-SAT?
Нет, один dfs. Действуем как в алгоритме разбиения графа на двудольность с той лишь разницей, что когда мы проходим по ребру, на котором есть асфальт, две вершины, связанные этим ребром, должны быть в одной доле.
UPD: Заходит.
У меня одного были проблемы с претестом №11 в B?
При тупом переборе нет проблем на претестах
Мой анализ всех посылок выявил примерно триста сорок три (прописью: 343) посылки с таким вердиктом. Подробную статистику по каждой из посылок вы можете сделать, перейдя по этой ссылке.
First off, great problem set. Seems like many people managed to solve E (grats), I would like to know the trick!
I reduced the problem to finding a sequence of nodes (with repetition allowed) that by using XOR, and including the initial state, would yield only ones. If i'm on the right track you probably understand what I mean, if im not please ignore. Anyway, can somebody hint for the solution?
Not a sequence, but a set (doesn't make sense to paint a city twice, and also the order doesn't matter). Color blue the cities you're going to paint, and the other ones red. Now an asphalted edge means the colors of the cities it connects must be equal, non-asphalted — they must be distinct. Then see 2-coloring of graphs.
Thanks, I get it. Really neat explanation.
Как E решалась.Скажите пожалуйста.
Я решал так:
Каждый город надо ремонтировать не более одного раза.
DFS.
Не знаю, насколько это правильно:-)
UPD : WA-43
я решал через двудольный граф. (если дорога без асф. то города в разных частях если с асф то города в одной и той же части) — если нельзя так разбить, то сразу есть ответ, затем выбираем одну из частей и выписываем (в том как выбирать я не уверин :( — посмотрим по тестам)
Lame...I totally ignored the alert that an all white fractal and an all black fractal are valid fractals.
И все-таки, надо признать, авторы жестко ошиблись с разбалловкой и сложностью задач. Самая жирная Е решается в разы больше, чем С... Мир встал с ног на голову
Почти на каждом раунде мир аналогичным образом переворачивается. Так что половину времени с миром все норм.
С на самом деле тоже очень просто решается. Динамическое программирование: z[mask][depth][x][y] — совпадает ли подматрица (x, y) - (x + 2depth, y + 2depth) c фракталом паттерн которого равен mask(маска из 4-х битов) и получен через depth шагов алгоритма.
это проще Е, все ок?
mask же незачем включать в состояние динамики, можно просто перебрать.
даааа... вообще можно вообще не хранить depth, x, y — хэши)
Привет 43 тест! :)
-
Regarding the rule: "_He divides the sheet into four identical squares. A part of them is painted black according to the fractal pattern._", I think the example for C is not illustrative enough...
I thought "a part of them" means one of the 4 parts... And it takes me quite a while to understand why a "2x2 black" square is a valid fractal pattern.
В задаче С есть анти-хэш тэсты, или у меня кривые руки?
Специально мы их не делали. Там просто много разных тестов. Вообще она без хэшей решается. Я писал выше.
Если хеш по маленькому модулю, тебя просто парадокс дней рождения валит, т.е. обычный рандомный тест. Я с пятого раза запихал такое решение :)
ну видимо как хэшировать, я сдал 10^9+7, видимо зависит от того, двумя простыми числами или одних хэшируешь еще
Может еще и второй ник свой подскажешь? :) Очень уж хочется решение посмотреть.
вот, как написал ifsmirnov, только по модулю 10^9+7
Да ты лучше ник скажи, так же интереснее
Если я правильно понял по сабмитам, вот он.
смотрю, кому-то неймется узнать... браво DryukAlex, как вам это удалось, гугл, или все сабмиты смотрели?
Только С и Е, мне хватило...
обратитесь к DryukAlex, он быстро выяснит
У меня сразу зашли хэши. Само собой, по вертикали и по горизонтали нужно брать различные основания. Модуль — 2^64. Я за две минуты не смог построить антихэш тест и бояться не стал.
с модулем 2^64 зашло
нет на вас Zlobober
Да, кстати, по модулю 2^64 должно заходить: ведь чтоб тот самый тест работал, нужна длина 2048.
Вообще непонятно, как можно в этой задаче антихэш тест применить.
по модулю 232 зашло
I am bit confused about sample given for Problem E(probably I am misreading problem).
example had
4 4 1 2 1 2 4 0 4 3 1 3 2 0
if road build go to first city 2 and then to 1, it would asphalt all roads?? after it go to city 2=> 1st road would unasphalt and 2nd/4th road would asphalted after he go to city 1=> 1st road would be asphalted
hence after 2 step it should get asphalted, can someone help me where I am misinterpreting the problem
You are absolutely correct, 2 1 2 Is an answer, however it's not said you should print the minimal answer so 4 3 1 2 3 Is also an answer.
Disregard
When multiple solutions exist, print any.
You are right.
2
2 1
is valid answer for the first sample test.
In this problem you can output any solution that need less than n steps.
I'm also confused about the sample, but it says
he asked you to make a program that determines whether you can "in some way" asphalt Berlandian roads in "at most" n days.
you don't need to output the minimum number of days, so 4 3 1 2 3 in the sample is also a correct answer.
I hope editorial will be available soon.
научите писать дфс, а то Е упала потому что написал
Меня секунда отделила от взлома решения, в котором подразумевалось, что граф связен >_<
да нет, я это понимал, там я просто перепутал, dfs(i) нужно было
Да, я понимаю, просто вспомнился один из фейлов этого контеста именно когда увидел этот комментарий.
там вместо
dfs(0);
неdfs(i)
?ааа нет не смотрите.... туплю уже(
ну да, все верно)
My solution to task E First we notice that doing the operation (asphalting) on town X will XOR all the roads coming out of it, so it's obvious that you don't need to do the operation (asphalting) on the same town more than once. (XOR-ing a road 2 times, is the same as XOR-ing it 0 times) So as we know that, we know for every town, we either asphalted the roads coming out of it once, or we didn't at all. Now let's take a set of connected towns (you can reach each town in the set from each town in the set) , Now if we know for one town if we asphalted it, then we can find out if we asphalted for each of the towns in the set. Example : We take a random town in the set and say we didn't asphalt it, we check every town he is connected to with a road that is not asphalted, obviously the other town must be asphalted if we want the road to ever be asphalted, and we check every town he is connected to with a road that is asphalted, obviously the other town shouldn't be asphalted. This way we repeat for every new town we find and because it's connected graph, we will find out for all of them. Now if we get for a town, that it should be asphalted and at the same time not asphalted, we got impossible situation. Then we repeat the whole thing but saying we asphalted the random town we took. So if both cases return impossible, we print impossible, in other case , we stop looking at this connected graph and say we managed to do it , then we proceed and take another connected set, doing the exactly same thing. If we end up doing all the sets without problems, we print the towns we asphalted from (we memorize them). Since we said a town can be asphalted at most once, the limit, to asphalt at most n towns, doesn't really do anything (asphalting all towns will result in n asphalts).
Sorry if i didn't explain it quite well, just thought i'd share my idea with you, it worked and i got 54th place :)
Nice problemset, but one question. How did you define a "fractal pattern"? naturally thinking, why a pattern with 0 or 4 blocks in black grids is vaild, with exactly 1 also works, but doesn't for exactly 3 black grids? It has just gone beyond my imagination..
Why doesn't it work for 3 black grids?
I'm still confused... can you list out all "fractal pattern"? easy job for there will be at most 16.
There are exactly 16 fractal patterns. Every cell can be either black or white regardless on other cells.
Thanks. Finally I realized that "A PART OF THEM" means arbitrary instead of exactly one of them.
Can you update the rating please so I can sleep well ?
or bad, in my case
контест два два восем рулит.два два восем есле в архиве
Ну вы поняли
Мне в Е на ум сразу только кинулась система линейных уравнений. Там вроде все просто — обычный Гаусс по модулю 2. У меня зашло. По времени — отлично.
Did anybody model the problem E with 2-SAT my solution failed in test case 43
if c == 0 then either of a or b can be taken but not both so i did this: (a or b) and (!a or !b)
if c == 1 I initially did (!a or b) and (a or !b) and (a or b)
It gave Impossible in first case
Why it did not work?
Intersting. I tried to solve this problem by creating a linear equations system with m equations and n variables, taking XOR (or plus %2) on everthing.
This approuch is different from yours but I think the idea behind them are the same (you are modeling that a XOR b = NOT c like me, althogh you maybe want to remove the clause (a or b) for the case c==1, to make (!a, !b) possible).
I also failed in test case 43, so I think it was probally for the same mistake. Does someone know why this idea could fail?
UPD: Got AC. My code just contained bugs, not related to this ideia. It must be correct.
You can read my comment below, I used this approach to get E passed.
I think this formula is not correct: "if c == 1 I initially did (!a or b) and (a or !b) and (a or b)"
The part (a or b) is wrong, because when (a = 0 and b = 0) it return 0, but actually in this case it should return 1.
The correct formula should be: if c == 1 then (!a or b) and (a or !b)
Thank everyone. @pele yah you are right i did not handle when both of them can be 0. deleting (a or b) got AC.
Again thanks.
For those who are seeking for non dfs/2SAT solutions in E:
Actually it is a system of Boolean equations with 2 variables each, the condition is to set the edge connecting i and j to be colored, with given color condition k (either 0 or 1). So we get for each edge, an equation like
and can be rewritten as
You will get m equations for n variables. Note that there is no unique solution (if it exists) since there are no two different equations with the same pair of variables with different coefficients on LHS (it's just 0 or 1 anyway). It means that if solutions exists, there is at least one slack variable, and the solution size is always less than n.
Solving the equation can be done using Gaussian Elimination in O(mn2) time. A faster approach is to utilize the property that each equation has exactly two variables. when doing elimination, the row being update always contains exactly two variables as well. Suppose we pick the equation
with i < j. Now we want to eliminate
where i < k. WLOG assume j < k. You get
Steps to consider.
(1) We saw an equation being set with (xj, xk) such that
(i) if w = w', this is a redundant equation, we forget it and process next edge.
(ii) otherwise, contradiction occurs, no solution.
(2) If we haven't seen such pair (xj, xk), and there is no equation with pairs (xj, xp) with j < p, we set up this new equation (that xj relies on xk for backward substitution).
(3) If we have an equation with pairs (xj, xp) with j < p and p ≠ k, we eliminate the obtained equation with it to get a new one with pair (xp, xk) (assume p < k). Then go back to step (1).
Hence we see that step (1) to step (3) would go at most n times, so we obtain at most n - 1 equations after processing m edges, and do backward substitutions. It takes O(mn) time.
Can anyone help me find the wrong in my submission?Because it's right when running on my own computer.thx.2261761
Make sure to fix these warnings first:
Why hasn't the editorial yet been published???