Всем привет!
Совсем скоро, 13 февраля в 19:30 MSK состоится Codeforces Round #167, автором которого являюсь я. Это мой четверый раунд на Codeforces и я надеюсь, что не последний.
Спасибо Жене Соболеву и Диме Соболеву (Seyaua и sdya) за помощь в тестировании задач, а также Геральду Агапову (Gerald) за помощь в подготовке раунда. Отдельное спасибо Марии Беловой (Delinur) за перевод условий на английский.
Разбалловка стандартная в обоих дивизионах.
Настоятельно рекомендую прочитать условия ВСЕХ задач.
Gl & hf ! :)
Контест окончен, поздравляю победителей див1:
1). tmt514
2). tourist
3). scott_wu
4). rng_58
5). dreamoon_love_AA
И победителей див2:
1). yefllower
2). Harlos
3). pseudopodia
Разбор по ссылке.
Are you sure about this date : "Sunday, January 13th at 19:30 MSK"
Guys according to your date the contest has been completed... because your date Sunday, January 13th at 19:30 MSK is gone....
''Настоятельно рекомендую прочитать условия ВСЕХ задач'',- и так каждый контест от Sereja :)
У него все задачи интересные. Лично я не могу успокоиться, пока не разберу все задачи второго дивизиона от Нагина.
Да всё задачи очень интересные !
Жалко, пропускаю вторые подряд соревнования из-за инста...
забей на инст. кф круче:)
А что такое инст.?
Если я правильно понял, то инст. = институт.
Лабы по операционным системам, не могу...
Жалко, пропускаю второй подряд инст из-за соревнований:)
На прошлом его контесте шикарная дпшка была !!! Думаю и на этом тоже мы что-то похожее увидим
Взломаю любого кто окажется в моей комнате!!!
Берегитесь серого взлома...
Даже тех кто не решил XD
Даже если сам ничего не решил.lol
Даже себя походу взломает...
Серые наступают! Берегитесь!
Охохохо, эпично проиграл с местной дедовщины.
After 7 rounds, all the 3 digits of this round is strictly increasing :)
Here 167 is a prime , 67 is a prime && 7 is a prime as well :D
scoring??
they'd say if it was unusual (i mean it wasn't 500 1000 1500 2000 2500)
в ОБЕИХ дивизионах??
Ошибки орфографические, пунктуационные, грамматические лучше подсказывать в личных сообщениях. Не все владеют русским языком отлично, к тому же многие допускают ошибки.
daje teh kto ne reshil))) XD paca
Ахтунг!
А. Даже так. Я ее помнил, с какого-то из прошлогодних этапов кубка.
а как решать? я послал стрессящееся решение, которое берет рандомное насыщенное паросочетание и удаляет его.
Все значительно проще. Берем любого у кого много. Переносим в другую часть. while (true). Сумма ребер внутри уменьшается, поэтому все закончится.
Это получился квадрат. До линии или MlogN доводится просто очередью или сетом.
прикольно. а отрицательный ответ там возможен?
клик-клик
Ничего не знаю... я случайно посадил багу, так чтобы оно работало за квадрат и он получил AC=)
Правильно ли следующее решение? Отнесём всех коней к первой группе, затем по очереди будем удалять всех коней, у которых есть 2 и более врага в данной группе.
Мне вот интересно — это специально? Автор матча мог и не видеть задачу, в это я еще поверю. Но ведь Seyaua и sdya Тимус решали. И кубок вроде бы тоже. Они решили, что такую задачу можно допускать на матч СF?
Но ведь там ограничения другие, и можно решать за квадрат, так что даже если и знали, почему не дать?
Мы вот давали Jedi Tournament в Петрозаводск со слегка другими ограничениями, и никто вроде не жаловался)
Мне кажется, что главное — это чтобы Gerald ее раньше не видел)
Более того, решение которое получило АС на тимусе, тут получило ВА 13, уже с дорешки отправил) Но оно явно багнутое, так что кроме слабых тестов тимуса обсжудать нечего)
Rishat_Ibrahimov used #define long unsigned long long and that costed me a wrong challenge, shouldn't that be considered code obfuscation?
No, you should read the code properly
div 2 D,can it be solved w/o chinese remainder theorem(CRT).
Let's sort all pairs. There can be equal ones, which can be now easily recognized. If there aren't — the answer is (n+m)!, obviously. But if there are, we should divide our (n+m)! by number of equal pairs (since 2! = 2; if there were equal triples, we might have divided by 6). Division goes using Fermat's little theorem since we're using modulo.
Edit: forget about the theorem, those 2's are from factorials, as MohallaBoy noticed.
What do you mean by (n+m)! ?Can you show some details?
I'm very sorry about misinformation — only yesterday before resubmitting D I realised that I wrote incorrect part of solution here. Please disregard it :) There's an editorial for now.
basically you to find values like (n! / (2) ^ k) % m You can do this by removing 2's in the numbers which are used for calculating factorials. and taking then modulo m.
first recognize all equal pairs, then for each repetition of the x term we calculate (length)!, omitting a 2 for each pair earlier. Although im 100% sure this is the solution i didnt implement it well enough for pretests :(.
When we calculate factorial let's just divide each factor by 2, if there is any pairs left. Even if we use chinese remainder theorem, we can't calculate modInverse of 2 if 2 is divider of our modulo.
The answer is integer so when we got our answer badCount == 0
Кто нибудь писал по D O(N^3 log^2 N) решение? На сколько быстро работает?
any ideas for solving C Div 1 ??
Edited : I was wrong !
Randomly distribute horses in 2 parties. Now if each horse has at most 1 enemy in its party, this distribution is correct. Otherwise, there exists horse A in party 0 that is enemy with horses B and C in the same party. Now move horse A to party #1 and it'll have at most 1 enemy in its new party. To prove this solution works, just define an invariant as count of enemy pairs in same party. Observe that after each move, this invariant decreases and hence our procedure is finite.
How do you prove that if this method fails to find a partition, then a partition is impossible?
Actually, when our invariant decreases at each step, it'll eventually reach 0 which means we are left with a correct distribution of horses in 2 parties. Possible partition always exists and it may not be unique but our algorithm guarantees to find one :-)
Sorry for being picky but I think it's variant, not invariant.
You're right. Thanks for pointing this out. Topic of this problem in Combinatorics is invariants and that's why I confused them :D
I think it is called monovariant.
Imagine, that all the horses are in part 0. According to your alrorithm, firstly we move horse 1 to part 1 (enemies 2,4,5). Then we move horse 2 to part 1 (enemies 3,5). Also we move horse 3 (enemies 4,6). Horse 2 now has 2 enemies (1,3) in its part. So, it doesn't work. Maybe I've misunderstood you, so please, can anybody explain me the correct solution of this problem?
UPD: All right, I understood you. But it was not easy to push it through TL (3126714). Maybe it's because of Java. Is that an optimal solution?
Complexity is O(m) and the idea behind this solution comes from a known graph problem. So I reckon this solution is optimal.
Угарный контест B — шку на последних 15 секундах сдал :D
Везёт, я её вообще сдать не сумел. Кто-нибудь сталкивался с ошибкой на 14 претесте?
Сам спросил — сам ответил, забыл, что в C++ (long long) надо использовать не только при объявлении, но и преобразовывать в него при операциях. Придётся ждать досдачи.
Та же фигня. Искал в этой задаче тупую багу весь контест, в результате за 5 минут до конца нашел)
Sorry for tourist. How fast he was. But even this didn't help him to pass Pretest 0 ( Compilation ). 3123727 and 3123677 :)
PFFFFFF)
заходил ли в С рандом? и как ее вообще решать?
:S DIV 2.B: Any one have an idea that why 3122613 has wrong answer on pretest #8?! I'm really sure that it should produce a correct answer. :S
ans++ , seriously , it will TLE
What does TLE mean?
TLE = Time Limit Exceeded
But System's Test say "Wrong answer on pretest #8" rather than any TLE!
You shouldn't
continue
ona[i] == a[j]
at line 40.And you use insertion sort which is O(n^2). I think it will timeout before finishing input.
DIV1 D is an original problem.
http://community.topcoder.com/stat?c=problem_solution&rd=14422&pm=11179&cr=10574855
TopCoder has its harder version.
one of the best contests ever..!!
well balanced on thinking and data structures...
wasn't anyone fool enough like me to use segment tree for div 2 C.
well, i used BIT
submission in queue...
I used Fenwick Tree for that problem :)
and fingers crossed.....:)
I think you don't notice A[i] <= A[i+1] , I'm too) But I did it after writing void build(.... )))
But even if it wasn't A[i]<=A[i+1] you can create sequence B such that B[1]=A[1] and B[i]=max(B[i-1], A[i]), so this assumption wasn't really necessary ; p.
No, you weren't :/ Segment tree consumed all of my time — I should have read D first...
lol, i wanted to code it, but then i saw a number of acceptions for this task.
I use segment tree, too. I've got some MLE after some TLE and finally I forgot to use
long long
.same here :) I got it Accepted and also I apologize to Segment tree for using it in this easy problem
atleast u got AC,long long cost me WA....:(
I was fool too :(
I didn't notice that the stairs are sorted
I also didn't notice that boxes fall from the left until I coded it
anyway I was fooler because my code was fail on test 45 because of overflow :(
It looks like the only difference in kissbuaa's and xiaodao's 2000s is the link in the beginning.. ..which is pointing to the same solution, yep. http://mirror.codeforces.com/contest/273/submission/3115085
http://mirror.codeforces.com/contest/273/submission/3114783
The same http://community.topcoder.com/stat?c=problem_solution&rd=14422&pm=11179&cr=10574855
I solved this problem after read this about one year ago ... > < .. I lost some of my code after a hard-drive broken and can't log-in to TC to access my solution. (because there is a SRM 2 hours early .. ) This is not a hard dp problem, but need implementation carefully. Even if I solved it before can't ensure I can solve it on the contest within the time. (I even didn't have a Java Complire on my laptop ... so only change the code under a text-editor ..
.. PS: The DIV 1 C is also a original problem ...
Can Topcoder work without java? LOL~~~
考挂自己弱,xlk 最弱!。
Orz xiaodao, Orz xlk div1 C can also found here:http://acm.timus.ru/problem.aspx?space=1&num=1128
There are more than 2: 3122346
3121856
3121632 (change variable names?)
3120914
3119084
and there might be more...
I wonder how could you find them?
Как D решать? Так и не смог придумать состояние динамики -_-
Кстати, как по мне — нехорошо получается с этими напоминаниями по поводу 64битных чисел.
Так как их всегда ставят в задачах, где ответ не влезает в int — то это является неявной помощью участникам.
Вот сегодня я считаю свой результат по первой задаче — незаслуженным. Я бы сдал решение в интах (с переполнением), и тем более никого бы не ломал, если бы не было этого напоминания.
Надо или писать его вообще в каждой задаче, или где-то отдельно напоминать.
Эх, а я не заметил. Хорошо, что поломали достаточно быстро.
Да ладно, все равно было куча взломов по А на переполнении. Мои, например, все на этом.
У меня тоже все 6 на переполнении:) Но все равно есть подозрение, что таких как я — которых спасло напоминание, — довольно много.
Да я тоже об этом подумал. Наверное многие, как и я, дописали 64 перед тем как сделать сабмит)
I have seen Div 1 C problem in Soviet math olympiad in 1979. This problem is "Proof that there always exists answers."
http://acm.timus.ru/problem.aspx?num=1128 It is here.
I have seen this so many times :D. I have even coded exactly the same task and did this problem with 2 of my pupils as a classic problem for variants :P.
теперь если меня спросят, что значит "упороться" я скину им этот код: http://mirror.codeforces.com/contest/272/submission/3122354
I've accepted problem C Div 2 at 1:29:22 ( Only 30 seconds untill the end of contest) ! I wonder if it was a record!?
You can easily check it on the status or standings page
How to get test case data on which our program has failed.
Since test input is large so It is showing only part of it.
i was about to ask the same question !!!!
it's not possible in CF :)
An untidy way.. but if u really really need it you can make a hack.. Just print say 20 tokens once (or whatever size fits in the screen), then next 20 and so on..
Хороший проблемсет, мне понравился) не смотря на то, что баг на задаче Б немного бошку поморочил и на нервах поиграл, я рад) спасибо организаторам за то, сделали эти 2 часа самыми захватывающими для меня за этот день)
Почему не завершается тестирование Див.2? 10 минут уже стоит на статусе "Системное Тестирование, 100%".
Обалдеть!.. Оказывается, из фиолетовой полосы выход существует!;)
Господи, да почему же я такой неудачник?! Я никогда не стану красным! После прошлого раунда у меня было 2145 рейтинга. Через некоторое время что-то изменилось (хотя место в раунде осталось неизменным) и 1 рейтинга у меня отняли. Как результат, после этого раунда у меня этой единицы и не хватило до красного цвета. Когда граница красного была равна 2000 я уже устанавливал 1999. Теперь 2199, при границе в 2200. Надеюсь, что в этот раз пересчет будет на моей стороне.
Что за странные мысли? Отбрось пессимизм.
Вот у меня было 2199 здесь, так же было 2198 на ТопКодере.
Красным я не был ни здесь, ни на ТС. Да и по жизни я конкретный неудачник:)
Но, тем не менее, у меня не только нету мысли о том, что я не стану красным. Даже наоборот, я вполне уверен, что стану красным на обеих сайтах в обозримом будущем.
Вот видишь, какой несправедливой бывает жизнь.. Там чувак взял решение из ТК (такой молодец, решил D за 9 минут!), и стал красным. А вот не сделай он этого, он, скорее всего, оказался бы ниже тебя, и, кто знает, может, это дало бы тебе недостающее очко рейтинга.
Вообще, конечно, надо этого товарища из сегодняшнего рейтинга удалить. И другого, который идиентичное решение заслал, — тоже.
Привет, Саш. Спасибо за поддержку. Теперь мы оба в клубе "2199" :) Да скорее всего никто ничего снимать не будет. Здесь такое не практикуется.
Prewritten code на Codeforces разрешен.
Так что проблема скорее в том, что на матч дают такие задачи (из которых сразу несколько подозрительно быстро решаются за счет того, что задачи с бородой), чем в том, что кто-то этим пользуется.
Спасибо за критику. Но как предвидеть, что задача уже не была?
Никак.
Если конкретный автор не видел конкретную задачу — его редко можно в этом винить. Все задачи в мире ведь перерешать не так уж и просто. И просто перечитать — тоже задача не из легких)
В данном случае меня интересует другое. Те, кто помогал в подготовке этого раунда, и точно видели боянистую задачу (Соболевы, к примеру, которые точно видели задачу С) — как они отреагировали на такое? Это было что-то вроде "ну ладно, ты ведь ограничения поднял, теперь надо не просто взять тупой код к старой задаче, а зайти на форум в поисках умного, или дописать несколько строчек"? Или "Тимус? кто же его решает в наше время в русскоязычной среде... Все нормально, никто ничего не заметит"?
Так вышло, что это единственная задача, которою они не читали.
Неудачное совпадение, бывает:)
Ладно, хватит о плохом.
Спасибо за раунд, ведь в общем все было очень даже неплохо — условия хорошо написаны, обошлось без лишних кларов, тесты тоже вроде бы в порядке.
Ну это не совсем pre-written code. В Codeforces FAQ так и написано, что не нужно вставлять в решение чужой код. Если бы люди копировали собственное решение той задачи, то его можно было бы назвать pre-written code и тогда уже претензии было бы сложно предъявить.
Фактически оно так. И понятно, что это не очень "честно" со стороны участника. Но формально ведь никто ничего не нарушил. Допустим, я могу за несколько свободных вечеров перепечатать вручную по одному работающему решению к каждой из задач ТС SRM. И сохранить их у себя в папке с алгоритмами. Для наблюдателя со стороны разницы между этой ситуацией и ситуацией, которая описана в теме выше — никакой. Разве что пользователь сам попросит "забаньте меня, меня совесть замучила".
Prewritten code (чтение, макросы и т.д.) разрешён. Prewritten solutions — вряд ли. Prewritten solutions, написанные кем-то другим — точно нет.
Воспользоваться тем, что ты уже видел эту задачу — значит по-быстрому написать решение. Это не значит по-быстрому найти его у себя на компе, или, тем более, в Инете. Здесь соревнуются в придумывании и реализации своих решений, а не в поиске готовых.
Это, в конце концов, просто неспортивно.
А ещё неспортивно давать бояны, притом настолько очевидные.
Кстати, а не правда, что solution состоит из code и, соответственно, множество solutions является подмножеством code?
Саш, уже не модно быть честным и все писать с нуля. Нынче модно чужие решения засылать, советоваться между собой и всячески читерить. Сколько не смотрю на нынешнюю молодежь — аж руки опускаются. Видимо в наше время понятие чести и честности было более развито. Я считаю, что ты прав и засылать готовое решение было попросту неспортивно. Сколько раз мы сталкивались на контестах с баянами и ведь не приходило же в голову лезть в интернет и искать свое старое решение...
Мне бы твои проблемы :)
А как решалась C(div1)? Времени было полно, но всё равно не смог придумать..
76 contests and 18 months of ups and downs and finally I get to taste Division 1 in Codeforces, the place where I started online programming.. May be small thing for others but it means a lot lot to me because this is where I started from.. Sometimes getting close and then falling back and sometimes no where near to the horizon..Yes... Now I can proudly say that I am Div 1 in codeforces and topcoder together .. I dont know how long I am going to stay here but just being here is a great feeling... :) I hope I will never see Div 2 again.. Thanks to the author Sereja and Egor as always for CHelper
Gotta thank Sereja for the best contest in my whole life. Couldn't be better than this for me! :D
It's because You became candidate master and solve five problems?
Well if You can solve C segment tree with updating on segments, it doesn't seem so simple. And if You solve D in few minutes to the end, it doesn't seem so simple too.
Просьба помочь найти ошибку в решении, задача Д див2, WA на 44, идея решения — факториал с учетом точек в одной координате (с замечанием, что в одной точке пространства не более двух точек) http://www.codeforces.ru/contest/272/submission/3120115
Проблема в том, что ты делишь по модулю. А так нельзя. Пример: Рассмотрим взятие по модулю 6. По модулю 6 числа 4 и 22 равны, но (4 / 2) % 6 = 2 ,(22 / 2) % 6 = 5.
Спасибо, забыл найти обратный элемент.
Его может не быть, так как модуль задается каждый раз разный. Я делал так: заметим, что деление на два необходимо только для вычисления С из n по 2, то есть в формуле (n * (n — 1)) / 2. Это можно посчитать точно в int64, а потом уже взять по модулю.
На самом деле можно было разложить факториалы на множители: 2 и все остальное. Тогда просто выходит.
А где разбор то?
Подозреваю, что он скоро появится здесь.
I did problem D in div2 carelessly and WA for 4 times in the contest. At last I only got 880 for this problem... But my rank seems OK...
Ignore it, I didn't understand you.
The same to you. I solved the problem D 5 minutes before contest just because of my carelessness.
what happened to your tutorial link?
The tutorial is written in Russian, it hasn't been translated now. Only Russian vision is visible... So just wait them to translate...
в первой задаче чекер был не правилным в примечании было написано что 1 1 ответ будет 1 либо 3 либо 5 я выводил 1 и у меня Wrong answer
Нужно вывести количество ответов
http://www.codeforces.com/contest/272/submission/3128898
i don't understand the fail of my solution ?
As you use C but not C99 you must declare i and j before the loop:
Can you give me a small test case where my submission fails. Thanx in advance
There is a problem:
cnt can be equal to 105, so overflow will happen.
my bad :( .... should have noticed earlier :D . And thanks a lot Fefer_Ivan :)
Не заходил пол-года, а Гена все еще первый в рейтинге
By python, I can not solve C in Div I! If anyone know, please post it!
The input is n<=3*10^5, m <= 9*10^5, about 10^7. It's just too large for python. My C++ solution cost 375ms and my python solutions are always 10 times slower. So I guess python need about 4 seconds for each test case.
yes, I think so. I also meet this issue. I implement C++ and python with the same algorithm. The C++ code is accepted in 500ms, but the python one is not.
can you explain about the second argument in your
change
function? Your solution is recursive. I can convert it to non-recursive version if I understand the trick.