Привет, Codeforces!
Мы с 74TrAkToR рады пригласить вас на наш совместный Codeforces Round 662 (Div. 2), который пройдет в 07.08.2020 17:35 (Московское время). Он будет рейтинговым для всех участников, чей рейтинг ниже 2100.
Задачи были придуманы и подготовлены AlFlen и 74TrAkToR. Мы также хотим поблагодарить всех, кто оказал нам бесценную помощь в подготовке этого раунда:
- Нашего координатора 300iq за терпение и помощь с идеями.
- Нашего дорогого друга lapochka_queen за идею одной из задач.
- Наших тестеров isaf27, Astralpirate, sava-cska, Siberian, voventa, romanasa, antontrygubO_o, DIvanCode, _overrated_, Mlxa, plagues, Prokhor08 за качественное тестирование раунда и важные советы.
- А также команды тестеров: ainta (ksun48, 300iq) и акацуки (p1rattttt, kostyamyasso2002) за тестирование на должном уровне.
- MikeMirzayanov за прекрасные системы Codeforces и Polygon.
На раунде вам нужно будет помочь главным пони из мультсериала My Little Pony (Флаттершай, Эпплджек, Искорка, Пинки Пай, Рарити, Радуга) и решить 5 задач, одна из которых имеет две подзадачи. У вас будет 2 часа на их решение.
Разбалловка будет объявлена ближе к началу раунда.
UPD: Разбалловка 500 — 1000 — 1500 — 1750 — (1500 + 1500)
UPD2: Разбор
Желаем всем удачи и высокого рейтинга!
As a tester, give me contribution, please:) UPD:( UPD1:)) Thanks you.
Unrelated question: How to become a tester?
I'm asking for real, not for gaining contribution. ;)
Basically, testers are friends of the authors. Also, some testers are people with a lot of contribution.
As we can see, people with negative contribuion can become testers too.
Aahhh! I see.
Going to google now "How to make friends in codeforces". ;__;
For making friends in codeforces there is a star in the profile page next to the handle!
More seriously, it is good to be a friend of the author IRL.
LMAO, I know how to add friends in cf lol. By doing that how will the other person know I've added him as a friend.
I was referring to getting in touch with contest hosters and problem setters.
err I think you got it wrong.
The reason testers have high contribution is because they gain contribution after being a well-reputed tester, not necessarily because they started with high contrib.Basically, testers gain contrib, so to say all testers need to start with high contribution is a logical fallacy.
You can ask about it MikeMirzayanov or if you know problemsetters you can ask they.
Cool.Cool.Cool.Cool.Cooooool.....
You mean like message MikeMirzayanov???
Yes.
Sent this message 4 months ago.....
It's like messaging Mark Zuckerberg on Facebook..... :D
become tourist. then everyone will want you to test. the end.
.
u dont have idea how ugly the question statements are and kind of worthless .
Shittttiest contest ever
writing this while contest in undergoing predict my frustation level..
You can't even solve div3 problems. stop bashing.
Yea i can see who is saying this the one having 12000 rank in prev div 2 contest .Keep up the good work .
At least I was able to solve 3 problems in div3 round where you cheated.
See how much spare time u do have checking on random peoples u wanna be one on one ping me we will talk there . Crybaby there is an iitian in the house
What's the point of being an IITian if you still have to cheat?
Maybe he is of reserved category, lol
Yeah i am if u are such a racist thiugh u should know in india caste discrimination is a crime .
Dude, you got the seat because of your caste. Why do you expect others to not call you a reserved category guy?
Deserving people sacrificed their seats so that you can study there.
sorry
thoufond
You know you can be punished under the provisions of the Scheduled Castes and Scheduled Tribes (Prevention of Atrocities) act, 1989?
Bro!! It is a humble request .. Please don't lower the standards of IIT's in our country unless you are from reserved category(PS: then you took the seat of other deserved candidates due to some shitty political policies). If you are an IITian.. good for you but then if you need a tag on your shirt stating that.. sorry bro you don't deserve it. PS: I was deeply frustrated after reading your shitty comments and so had to write all of it.
Does 'skipped' means that he cheated?
Yes
Ya ankit i respect your words but the thing is i submitted one of my friends solution coz i wasnt willing to go further in the contest as i got some work i heard somewhere that if you copy someones code the contest will be unrated thats all i did . And i dont know what is the point of this guy to just poke in my comment worthlessly out of nowhere kinda frustating already the contest was not up to the mark so thats all .. Anyways i feel bad about my prev comment :) thanks dude
yeah sure, you submitted for the 3 problems for it to be unrated and not for only one or two problems :)
Thanks, you helped me find my food.
It wasn't unreadable though..
As a tester , were u able to understand the problems ?
The Pretests of question number 2 should be strong. My code Passed pretests but failed after. I am just giving feedback and not complaining. It's real heartbreak to see that red written "System test fails"!
!
girl
Pony
Sexy !!!
SIMP!
LOL
ARE YOU A GIRL OR A BOY?
Boy
74TrAkToR, are you a boy or girl?
boy
there goes all hope.
What was this girl and that explanation mark and that pony, shit posting or something very deep?
Why 6 ponies but 5 problems?
The 6th one might be the over smart one creating a harder subtask.
The 6th is me : )
Did you change your dp for making that comment?
I use my little pony to denote my max delta.
before it was this, because my maximum was a pupil
The 2 of the ponies are twins as 2 subtasks.
Nice pic for seek attraction!!
I feel old now ;)
I love watching "My Little Pony" cartoons, so I look forward to this contest!
But I am not a girl ;)
Me too. It's great but seems not to have more stories :(
when a newbie like me see a contest has 5 problems, Oh no this means I will only solve 1 or 2 maximum :/
This cartoon is interesting and I hope the problems are short and interesting too!
As a participant , give me contribution .
UPD :(
What are all the possibilities when a contest submission gets "Skipped" ?
All possibilities except when no one cheats.
So if we ensure no one takes my code, it won't get skipped, is it?
Yes, avoid using online IDEs like ideone, because if you forget to make the code private by any chance, anybody can access it. Also, you mustn't intentionally give your code to anyone.
But how can anybody get ideone public links? The person has to share the link right?
No, I guess it's available on the site only, something like recent public actions is available there.
Actually it happened to me one time when I started CP and used ideone then. In a Codechef Lunchtime, after someday I got an email that my submission got plagiarised due to same code matching with 2 other person's submissions. When I took a look at their codes, their codes were clearly my code with some added unnecessary comments. At that time I came to know about this ideone public access thing.
Currently, Ideone has removed the pubic link of recent submissions which may lead to a decrease in cheating on CP platforms via ideone.
Ohh, I didn't know about that. Haven't used ideone for the last 4-5 months. Nice to hear it though.
If your code matches with anyone...if you copy from other or someone copy from you...both of you guys's submissions will be skipped :3
Is series is available in YouTube :-)
Typo: Pinkie Pie is not Pinky Pie.
Also that's a good theme! (I am a brony)
omg, I'm sorry... I fixed it by the way.
я май литл пони не люблю.
я ненавижу май литл пони, и делайте со мной что хотите.
и мне по барабану.
вот я вот, вам говорю: я их ненавижу.
и че?
I like how people think memes will gain upvotes. THE MEMES HAVE TO BE QUALITY!!!
quality is a noun :v
Grammar...nah.
AlFlen If possible can you guys please add some kind of divider between the fairy tale and the problem statement so that people who are only interested in the problem statement can directly jump into it? no offense just a suggestion
We tried to make statements rather short. The legend doesn't occupy a noticeable part of statements so I think it'll be comfortable enough for you to read and understand them.
Thanks for a prompt reply!
LOL
Well, that like semi worked.
Thanks for making the statements really very short.
Never seen statements shorter than this.
one of which has two subtasks.
That's interesting !!The second pony from the left does codeforces rounds :GWagnwChinoWoah:
Orz
HEllO
i dont like pony
Hope it will be queue free contest..
Yeah, we don't want the system to stall.
My daughter loves My Little Pony, she should take care of this round...
Parents are doing codeforces nowadays. Damn! Thats why I love codeforces
from 5th standard Russian students to parents, from newbie to world top coders, you will get each category on codeforces. That makes competition more interesting.
Hi ainta!
As a testers, I'm not a tester :)
To my disgust, I actually thought those ponies were standing on two of thier legs and I wondered what that third thing was.. figured it out now.
I cant unsee it, it will haunt my dreams forever
PONYFORCESSSSS UNITE
I now must watch my little pony now to try to get a better score on this contest.
Woahh, it's so cute <3
NERD_MAX = Helping My Little Ponies on CF.
Oh god unfortunately I cannot participate in this My Little Pony round because something has come up. How do I unregister from a contest? I can't find it.
Go to the number of participants link beside the contest and click it. There will be a cross symbol beside your name. Just click on it. Moreover, you can also not submit anything during the contest. It won't affect anything.
weird flex but ok
rotavirus is weird but fine
Never watched My Little Pony animated series but the contest seems interesting!!
Behind this cuteness, I believe there will be some dangerous problems. Best wishes to everyone. Go and be high rated ;)
ofc there will be some dangerous problems if problemsetter is severe highschool girl from Chelyabinsk
bronies everywhere...XD
Will I be able to finally get my colour?
wow, a second My Little Pony contest since Codeforces Round 259 (Div. 1)!
And now I am super excited to help these little ponies. Aren't you guys?
Great, yet another Pony Round!
One of the pony has crush on author. But he/she doesn't know which one. Help him in finding it out. XD
I didn't see Rust in the registration email. Is that a mistake or is Rust really not available for this round ?
What are the things hanging between the legs of the ponys'?
other legs of ponies
I didn't know sparkle is one of the main ponies. Thank you for this round, I'll be waiting for some nice puns.
Wow!
Wow!
The background looks so...cute?
BINOD
Автокомментарий: текст был обновлен пользователем AlFlen (предыдущая версия, новая версия, сравнить).
Finally... a perfect excuse to join a rated round after nearly two years!
Oh, it's Div. 2 only...
https://ibb.co/HHrbPmM
As a pony , I'll participate :)
when will codeforces support swift language? Sadlly, So many languages have been added to codeforces but not swift. Swift is really a elegent, efficent modern language! Hope administrator support swift someday!
when will codeforces support asm language? Sadlly, So many languages have been added to codeforces but not asm. asm is really a elegent, efficent modern language! Hope administrator support asm someday!
Are problems have been prepared on ponygon?
No, on Russian and English
Participating in this round while I have an exam tomorrow feels like suiciding
Well, it's your 189th. Your are clearly addicted.
My Little Pony animated series ...
A lot of thanks broh, now I can waste my next weeks n weeks watching them <3 =D
I am scared, I am noob and don't want my ratings to fall now.
Why worry? If ur rating drops, next time it'll be easier to raise them, never worry about that when participating in a contest.
Finally scrolling through a comment section where you can actually read the comments.
GL HF
Hey! Hello? Am I on the blogpost?
Well, guess what?
Yes, I am! And that's Awesome!
Problems setters, Pinkie loves you sooooooo much, too much that I want to throw a party!
Ready for contest!
I hate the story of problems! :(
For real...
This endless blah blah apple here flutterapple cakeapple there because fluttepie with cakeflutter there is only annoying. This is no fun.
Yup the cringe level was just off the charts!
No offence to problem setters ,but i am unable to understand the question itself.
wtf the statements say?)
Horrible statements. I couldn't even understand what was asked.
Can I get my ratings back by nothing playing this round :(
Yeah!! If you haven't submitted your solution even a single time, then you can leave the contest. There will be no change in your ratings!!
Is it an English Comprehension Contest?
Are we here to code or improve our vocabulary.Seems like its and Mock IELTS/TOEFL Tests.
Even they have to make 2 announcements for writing the correct question!! But till now I am unable to understand what they are trying to convey in the first question.
yea same with me...i cant understand how are the blocks kept..
yeah even i guessed about the question and solved according to that
Poor statements!! I am unable to understand even the first question !!
There was no need to have a sooooooo long story, it would be better to have a more mathematical statement than a confusing long story.
The names of the characters were so complicated to keep track off and the long stories. Sorry but not a good contest.
This isn't meant to offend anybody, I just posted it to make this very clear that problem statement is where one should give more time then framing story. No doubt problem statement could be better
This was just waste of time.... The problem statements were so confusing. Actually this contest was not of coding but english.
I dont care how pinky pie eats her patty cakes just tell me what I have to code for!
I hate the story of problems! :(
Not able to understand even first problem!
The statements should be simple. There is no need to always introduce a story in the problem. I am very disappointed after this contest.
Why the f*** do I have to see these DISGUSTING PONIES.
Why the fuck you want to include stories in problems, and these weird names- Rainbow dash, Flutter shy..... What do you think, by including stories, the round becomes interesting??
no more storyforces
How did all of the contest setters agreed to release these kind of statements?
Too much storytellings... Just give us simple statements please...
Contest in a nutshell: Read the stories and fall asleep. Setters be like.. Didn't understand the question? We did not want you to.
I don't like pony stories anymore.
It's really not that hard to write clear, concise statements.
It took so much time to understand problem A :-(
Nasty contest
To the guy who designed the problem statements: Hats off! You've a tendency to play around with words and over-complicate easy to understand sentences.
I planned to watch My Little Pony when I was reading the announcement, but after this contest, I would say no.
How to solve A after the contest?
Do not discuss problems while contest is running.
Yes, I know. I edited the comment now.
clever
n/2 + 1
How?
make an exemple for n=4 and n=5 on the paper.In the first step you can color the "1st layer" (near the border). In the second step the second layer and so on.In the n/2th step you will reach the mid layer (+1 for the center).
Am I taking an English examination?
The statements are too long and there are too many unnecessary(as I think) stories.
And there was even a typo in the statement of problem B. As you can see in the picture below, the two phrase "After the sixth event" came out incorrectly as "After the second event"(Only true for the latter). Although the typo was fixed after a while, there wasn't announcement about this. Moreover, I posted the comment similar to this about 1.5h before, but after about an hour, the comment was deleted for an unknown reason.
Why couldn't no one find the typo before the contest? Why there wasn't announcement about the typo? And why my previous comment disappeared? Not pretty good. :(
This round tested our English rather than our programming skills.
This round tested our English rather than our programming skills.
Just asking. Are the top rankers(in this round) even trying problem E1 lol
I have tried very hard on E1 and nearly burned my brain
Now I got a reason to hate pony.
This is the reason I don't upvote before round.....LOL
Exactly
Problems are nice but the wording of A really messed up my tempo. Also the names of characters (i assume the names of the ponies ) in the problem statement messed up the understanding of the problem to me for some reason. I would recommend maybe using some familiar and common english names.
Was I the only one who found C way easier than B (At least on the implementation side)?
For me the number of unpronounceable word in statements defines the hardness of problem.
Enough grid construction and heavy weight english word exercise for today. I quit.
How to solve D?
here
Let $$$dp[i][j]$$$ denote the size of the largest rhombus with the bottom vertex located at $$$(i, j)$$$.
Suppose the colours at $$$(i, j)$$$, $$$(i - 1, j - 1)$$$, $$$(i - 1, j)$$$ and $$$(i - 1, j + 1)$$$ are all the same, $$$dp[i][j] = min(dp[i - 1][j - 1], dp[i - 1][j], dp[i - 1][j + 1])$$$ + (1 if the vertex opposite to $$$(i, j)$$$ has the same colour as $$$(i, j)$$$)
If the colours are not the same, $$$dp[i][j] = 1$$$
Now, just iterate over all bottom vertices $$$(i, j)$$$ and count the number of rhombuses using the dp values.
Code: https://codeforces.net/contest/1393/submission/89259501
Wow, never got the idea using 1 dp. I got idea using 4 arrays. up, down, right, left.
Recently watched a video of largest square in grid, and applied the same idea here
Pretty nice trick :)
Why the fuck memory limit on D is 256 MB
Because $$$30$$$ MB is enough.
A dp from every corner so 4 matrix of 2000*2000 ? P.S. that s 4*16 mb so nevermind
only 2 dp arrays are enough! from the upper and the lower side.
only 1 dp array will also do the trick. Just take the minimum in second pass.
Waiting for more.
Yeah got the idea now! :)
I thought 256 MB is a normal memory limit?
No clue, but you can code the same solution by just considering for each character one at a time, doesn't change total time complexity anyway if you were planning on storing pref[26][n][m] or something similar.
I agree. That and the tight time limit cost me a good 150 points and 20 minutes and it must have cost others points too. The constraints were way too tight.
I have O(n * m * k) sol, where k is alphabet, and I'm getting TLE. Perhaps it was supposed to stop rotation or even force O(n * m), but seems v tight for little reason.
I had done using only 2 2D array(one for input and other for DP). So, size is 2*2000*2000*4 bytes = 32MB.
Can somebody tell me the idea behind problem C? I tried like everything. Thanks in advance!
Apply Binary Search MySolution
the answer will depend on the maximum frequency of a number and count of maximum frequency. To notice that see that if max freq is 3 , it occurs twice , you can make ab...ab...ab , now just from this you can notice that ans would be (n-(mx)-(cnt-1))/(mx-1), as you need cnt — 1 spaces from the end and to populate mx freq you need mx spaces , out of remaining spaces you need to partition it in mx-1 segments like ab...ab...ab , which is optimal when we divide them equally or just division. Link — my solution
but why only max frequency is considered?
because numbers having frequency lesser than maximum frequency can always be adjusted in the middle without lessening min distance
Because for other frequency we can insert them in empty spaces between those of max frequency and they won't come out of the array because they are strictly less than max, for ex — if 3 , 2 ,2 ,1 is freq array and numbers for them is a,b,c,d then there are 3 a's , we want maximize their separation first, so we equidistantly place them , so a...a..a, Now every value has freq<=2, which can be placed in each of empty spaces between these a's, so their min distance won't decreas
I did the same.
I used binary search to look for the solution. My solution passed the pretests but gave WA on test 43. I don't know where did I go wrong. Link to my solution: https://codeforces.net/submissions/i_m_eshaan17# Can you please see what thing I missed out
Wow. Nice Solution.
Look u have to find frequency of the number occuring most number of times. now find total how many numbers are there having this frequency int val=n-maximum_frequency-(count of numbers having maximum frequency -1) val/(maximum_frequency-1) will give the right answer .
Let us see this with 2 different examples {1,2,3,1,2,5,1,2,8,1} Here the maximum frequency is 4 and the number having this frequency is 1 so we can see answer will be 2 Now lets take change the example a bit {1,2,2,1,2,5,1,2,8,1} Here the maximum frequency is 4 and the numbers having this frequency are 1 and 2 so now you can see the answer becomes 1 {1,2,1,2,5,1,2,8,1,2} can be one solution reason is that 1 has maximum frequency so we arrange array like 1....1....1...1 we put 1 at both ends to maximize the distance and put other elements between 1s but when 2 also has frequency 4, two 2s will start falling between two 1s(something like 1,2,2,1.... So,every time we encounter another number having maximum frequency we need to put it at last (something like {1,2,1,2,5,1,2,8,1,2}) Look at the first test case for a bit of clarification
Was it just me or did others find the wording of the first question a bit difficult as well?
Today I get to know why we were taught English first then programming.
Though the concept and problem idea is good, I suggest the Problem statements can be used for essay writing competitions.
I'm doubting my English skill after this contest
I solved C and still can't understand A
I made upto 6 X 6 grids to understand the common pattern between them xD
Red is first step, blue is second, green is third...
upd: Its wrong
what is the pretest 5 of problem D?
Pretest 5 cost me 2 WA, but it was my silly mistakes...
Try this:
The correct answer for that pretest is
26
, right?Thats what my code is printing as well.
I was able to fix my code for that problem.
For those wondering, the pretest I used was
However I believe maksio's test should provide an error as well. The only change needed is change it to a
5 * 5
matrix ofa's
I see you have done DP similar to me too. The issue in your code seems to be that you are wrong in up and down dp.
You can see my code, bam is similar to left, dan is similar to right, up is dp1, down is dp2.
Basically, c should be updated as 1+2*min(bam, dan) and and d should be up[i+1][j]+2, not 1.
Bye Bye rating
The problems were good but the wording of problem A messed up my tempo. Also the names of the characters (i assume names of ponies ) confused more from understanding the problem statement. I would recommand using some common and familiar english names.
No comment
.
Look she has a rating which is much higher than mine and I am gonna get about +120 after this round but seriously this contest could have been better and what the fuck are you even talking about
She confused the contest with the storybook
You can choose to become a writer rather than a contest designer
What is the correct approach for C??
bsearch answer, then for each iteration, always greedily put down the number with the largest remaining frequency that is available.
Can you please, share your check function?
89248346
Where my check may fail
vector<int> v
is vector of frequencies of every element that appears more than once89275212
can you plz plz check this function https://codeforces.net/contest/1393/submission/89275288
can you please explain the logic?
no need to use bs :v
i mean sure, but for me it was easy to see a bsearch solution, and it fit in the TL.
My approach:
Count the frequencies of each unique element.
Note that if there are multiple most frequent elements, you can discard all but one unique element. If both
1
and2
appear as frequently as possible, you can just do1 2 .. 1 2 .. 1 2
. This reliably increases the distance between alike elements by 1.Note that the optimal arrangement for the most frequent element will always be
1 .. 1 .. 1
where1
is the most frequent element, and you fill things in the middle.All remaining elements can be inserted into the
...
spaces in some way (proof is left as an exercise). So we just count the number of how many things there are that aren't the most frequent, and divide by the number of spaces (the...
).What if the input is 112233. Optimum distance is 2 and it is achieved with 123123. But if we start with 1....1, then we can't get distance 2 anymore. The possible ways to fill the middle are 2233, 2323, 2332, 3223, 3232 and 3322, but they all fail.
I mention that in the earlier case -- because they're all the max frequency, we can treat
1 2 3 ... 1 2 3 ... 1 2 3
like1 ... 1 ... 1
and just add 2 to our final answer.You only need to fill things in the middle if their frequency is lower than the maximum, if they are the maximum you can handle them earlier.
Final answer is the sum of all frequencies $$$< maxfreq$$$, divided by $$$maxfreq - 1$$$, plus the number of unique elements whose frequency is $$$maxfreq$$$, minus $$$1$$$.
Binary search
Codeforces be like lets have a new member in the family : PonytaleForces !
storyforces
Lol what the heck was this contest
It was a english grammer contest,this contest increased my english reading skills :XD
D — это H отсюда(link), только вместо треугольников ромбы и вместо звездочек буквы(что особо не меняет суть)
Ещё очень похожа на C отсюда.
Впрочем, понятно, что такое совпадение заранее найти очень сложно.
what's the idea in problem C
Kindergarten question designer is better for you
I saw this coming thats why I tried confirming it here , looks like they were joking back then.
!
Seriously, they couldn't have given a more ironical reply
What is the approach to solve D?
Write stories if you want, but please at least give us formal definitions for the operations to be performed.
What is the approach to solve D?
for each cell we calculate the number of ways to form a pattern with center is the cell.
$$$up_{i,j}$$$ = Number of cell with same color above this cell
$$$dn_{i,j}$$$ = Number of cell with same color below this cell
$$$a_{i,j}$$$ = $$$min(up_{i,j},dn_{i,j})$$$
$$$b_{i,j}$$$ = max size of left half of a rhombus centered in this cell
$$$c_{i,j}$$$ = max size of right half of a rhombus centered in this cell
$$$m_{i,j}$$$ = $$$min(b_{i,j},c_{i,j})$$$ = max size of a rhombus centered in this cell
$$$ans$$$ = sum of all $$$m_{i,j}$$$
it should be $$$min$$$
Thanks. Fixed it.
Notice that all squares can be treated as a rhombus of size $$$ 1 $$$ and count them. After that remove all squares that can not be a center of a rhombus of size $$$ 2 $$$ add those left to the total number of rhombuses. Do this again for size $$$ 3 $$$ and so forth.
How can this be done?
Notice that a cell can not be the center of a rhombus of size $$$ n $$$ if there exists a cell of a different color such that the Manhattan distance between the two cells is less than $$$ n $$$.
Using this fact we can implement a multi-source BFS from all cells which have different colored neighbors and in each round count the number of cells that are not visited. (Be aware that the memory and time limits are quite tight).
Interesting point of view. Is it $$$O(nm)$$$?
Yes, because this solution is almost only BFS and the graph that the BFS is run on contains $$$ nm $$$ nodes and about $$$ 4nm $$$ edges. Therefore the complexity is $$$ O(nm + 4nm) = O(nm) $$$.
However the constant factors are quite large and I lost a good $$$ 20 $$$ minutes and $$$ 150 $$$ points (due to submissions) trying to optimize them. IMO the limits are way to tough and a solution with the expected complexity should pass immediately.
It's a competition where I've got the best result I hope I won't be hacked
When will the Editorial be published?
By the way, the contest you prepared was great!
My video editorial for Problem A and Problem C
why we can not paint 4*4 grid in two step
Because after two steps not all fields are painted.
why we can not paint cell (1,1),(1,3),(2,2),(2,4),(3,1),(3,3),(4,2) and (4,4) with one color in first step and all remaining cell with other color in second step
We want to have chessboard as result. So first is (1,1),(1,3),(1,5).... on all four sides.
Second is the fields in between of the ones from first, and every second fields of row/col 2,n-2. And so on.
You can't paint (2,2) in the first step, as it is not
neighbouring to the last painted cell
, Read the question statement again you missed this point.why only the elements with max count are required?
If you try to spread the elements across the array the ones with max count would end up closest.
Lets say freq of max element is 5 then u have X__X__X__X__X and u can place all elements of lower freq in different spaces so they will be atleast as far as a pair of X.
Because we are essentially dividing the array into groups right? So for the element which has max frequency
n/(fr[x])
element will be minimum hence the least spacingWhere I am wrong in Problem B!, I just counted number of active planks , with updating frequency table for each plank entry as entry and exit happens and also in this frequency table maintaining the maximum value and number of odd and even values, now the answer is YES only when maximum value in frequency table >=4 and also total planks %4==0 and no odd frequency is there in the frequency table else answer is always no.?
Where I am not getting problem statement please tell my mistake!
Thanks in advance.
You have to make only 2 storage.
You only need planks (a,a,a,a) and (b,b,c,c). {here a,b,c are sizes of planks}.
In total you need just 8 planks.
This is nice explanation. Knowing that the problem statement is understandable, too.
Thanks I think that I misunderstood the problem as in total we can more than one rectangle and square storages, confused with the word storages in the problem statement. Thus just one change of making count to 8 will make my solution pass, I dont know what is the sense of such problem statements and what they checked. Facepalm after losing 120 Rating again I gave the contest today as my mood was bad and I thought of freshing up my mood but Now I cant describe to what scale the statements worsened my mood again.
Did you read the announcement? I did exactly the same as you before reading it and it cost me 3 WA's and half an hour. :(
I didn't do well in this contest but could solve B.
Here is the way I did it, keep 4 sets (two, four, six, eight) two => freq[2, 4) four => freq[4, 6) six => freq[6, 8) eight => freq[8, inf)
Now as queries come, these tables can be updated on the fly in somewhat O(logn)
You can build when
8 has >0 members (2 squares)
6 / 4 has >1 members (2 squares)
6 has >0 members and 4/2 has >0 members (1 square, 1 rectangle)
4 has >0 members and 2 has >1 members (1 square, 1 rectangle)
the overall complexity is O(nlogn + qlogn)
You are basically missing lots of cases and also not all planks are required to be used, so the %4 check is completely incorrect
You can do it with much more simplicity. Just maintain a map to count the frequency of each element. Now take an array of sets with size 2 :
set<ll> cnt[2]
.In the
0th
position, insert those elements whose freq is >=2In the
1st
position, insert those elements whose freq is >=4Now, for each query do the following:
If we need to add/remove something, update both frequency map and the array of sets (check the count and see if we need to remove or insert something in
O(log N)
.And to get "Yes/No" we have 3 cases :
1. If
cnt[1].size() >=2
-> YES (we have 2 squares feasible)2. If
cnt[1].size() ==1
a. If the freq of the element is >=8 -> YES (we have 2 squares feasible)
b. Otherwise, see if you can construct 1 square and 1 rectangle by checking the size of
cnt[0].
3. The answer is
NO
.if we have 4 planks of length 1 and 2 planks of 2 and 4 planks of size 3. so total no of planks is 10(toatal planks %4!=0) so it will give no according to your code. But ans is yes
I think I misunderstood it as all planks must be used too bad mood today thanks buddy for figuring it out!
I thought C problem was easier as compared to the B problem or did I overcomplicated my problem B solution?
Can anyone plz tell me why getting WA on C https://codeforces.net/contest/1393/submission/89275288
i m using binary search to find the answer in binary search i m putting the no.s with greatest count first then the no.s with smaller count can anyone plz have a look
Try this !
This test case is wrong since: 1 <= a[i] <= n
Was there any edge case in B.I tried every possible combination still it gives wrong answer on Pretest 5.
Try going for 11111111
Really a lengthy and messy one , please keep to the point questions
Can someone please help me to figure out this issue. This was my cf submission 89275621 but in local PC my answer as was different.
Your go out of bounds on your A vector (you can start with only 1 type of plank).
can someone tell what was the pretest 4 in problem B ??
why only the no. with max count are required to find ans in C?
_pastor_
So it was a right decision to leave the contest after reading the first problem. XD
I appreciate the problems, but does anyone find that it was more unnecessary story, and had lots of ambiguity, specially problem B ?
Hoping to see Editorial without ponies.
Story forced me read the examples and guess the problem.
5- Ponies ✓
There should be some background stories but not that long.
5 — Fast editorial X
Problem D is very similar to this 1015E2 - Stars Drawing (Hard Edition)
I remembered that problem too, and I actually got a WA in contest because I implemented biggest star instead of biggest rhombus :P
(surprisingly, biggest star passes all sample tests)
biggest rhombus can be checked using 4 adjacent square values.
Yeah, that seems to be the simplest way after scanning through the comments.
I did eventually manage to pass pretests, but I did something a lot more complicated (2D prefix sums rotated 45 degrees).
I thought about rotating the grid at some point. I have a bad habit of over complicating things.
Also similar to https://www.urionlinejudge.com.br/repository/UOJ_1511_en.html,
we can use binary search here, and replace all the characters with prime number, so if gcd is 1 checking condition is false look for smaller manhattan distance, else if gcd == centre value, look for larger manhattan distance.
Was E dp by sorting for each char's disappearance and using hashing for fast string comparison?
I tried that, but got memory limit exceeded
you have saved strings multiple times which can be avoided by just storing only the index of removed character and comparing like this if you want to compare x removed index and y removed index of a string say x<y so compare s[x] to next char in string different from s[x] i am not sure tho :\
That makes sense, maybe I will try implementing that later.
I was thinking maybe using a Trie will probably also work.
hey, did someone pass B pretests using hashing ?
I used unordered_map in c++ to quickly update and query planks' count. But I ve got TLE on pretest 4 even if my program complexity is q^2.
Q was given to be <= 1e5 so yeah, it is gonna give TLE for complexity O(q*q)
Please stop writing problems like E
Can you explain your solution for E1, E2?
I'm lazy to write it, this is almost my sol by dorijanlendvaj
dp[i][j]=amount of solutions if you remove index j of string i looking at strings<=i add a space at the end of each string for each string you can sort indexes by the substring you get when you remove that index(how is left as an exercise to the reader, you can compare 2 substrings of 2 strings in log with hashing you can also compare (string x without index i) and (string y without index j) using 3 substring comparisons now you can do 2 pointers on the sorted indexes on this string and the previous strings to find which dp values of the previous string to add to the dp values of the current string
I got tle on system tests because I did everything with extra log, here is the same sol in C++17(64) :)
How were we supposed to do B? I finished this ridiculous method of using a python dictionary which maps to nodes in a balanced binary search tree right after the contest ended, but I'm 100% sure this can't be the solution to a problem which is B.
https://gist.github.com/bananabrick/a3676673ab072c1e6fe4fb3852ecbdff
I also used python. I used a counter to count how many of each plank there are. I also made 4 sets, for counts cnt>=8, 6<=cnt<8, 4<=cnt<6, and 2<=cnt<4. Update these sets as expected for every updated plank. To get the answer, check all possibilities that make a square and rectangle, such as any one plank cnt >= 8, or on plank cnt>=4 and 2 planks cnt >= 2, etc. There are a few other possibilities, and I think there might’ve been a better way to organize them, but this way worked after a couple tries.
From a mental health standpoint, the best approach for problem B is to give up.
My opinion only: I found B much easier than A.
My solution for B on c++, it only uses an array of frequency and 4 integers, i think is pretty self explanatory, but ask if you need extra comments on the code D:
I read the statements to my younger cousin, he enjoyed the round! Thanks StoryForces! :D
LOL
Thanks for the good questions from the authors, but the topic is a bit long. A disappointing round. In question b, I don't know how to extract the last three elements in the stl map. I used a search engine, but I did not find any useful information. So I keep trying. After trying for a long time, I finally figured out how to do it. after I pass b, it has only been 20 minutes. When I came up with the algorithm of c and wanted to start writing, the game was over. I don't know how to describe myself, it's disappointing. The only gain is to be familiar with the use of map.
since all x's are < 1e5 map can be replaced with an array
I know how to solve this problem with arrays now. So try to use things you are familiar with during the game, and learn more about things you are not familiar with at other times
Ponyforces
How to solve E1 & E2?
Problem B i feel like i did everything right yet it gives wrong answer on Pretest 2 :/
Anyone have a Java solution that worked for Problem B?
To be honest,you really need implementation skills.
can you explain how I can improve my implementation skills? I'm very new to CP and don't really know what that means.
Inspect the code for this problem written by top 10 in ranking. You will be surprised how simple the code can look.
You can check mine 89249695
Language could have been simpler and question could have been without the long and unnecessary stories. This would have made the questions and round much more interesting.
Not just the story and problem statements, but the test cases were not helpful too. I keep getting WA on B (Test case 2) and more sample test cases will definitely help.
First, i think we can glue two planks..
What exactly can be difficult to understand in B? Or do you want sample test cases to contain all edge cases?
It can be difficult to understand until we read the announcement. That's not cool
Good! story reading contest at codeforces
statements are so long ...
This contest was quite in favour of good English readers with great vocabulary.
Something which was not expected in codeforces.
Thanks for the free IELTS test.
The golang solution of A is wrong unexpectedly
It is too simple to program wrong
Anyone can help me ?
Add
\n
in scanfSee https://golang.org/pkg/fmt/#hdr-Scanning
Thanks. I change
scanf
intoscanln
and accepted. I will read the doc again.Problem D can be solved by BFS.
key observation: At one position, the largest diamond is the distance to nearest different alphabet.
my submission
But i got TL on test70 :(
Maybe log factor of storing input into map caused TL?? argh...
You can't run BFS at all positions, that would be quadratic in the number of vertices (which in this case can be $$$10^6$$$).
We can do BFS on each alphabet, and start BFS with the edge ones(maybe call this multi-source bfs?). Then we get distances of all that alphabets, and the total time complexity become amortized O(nm). accepted code
AlFlen The Problem Statement for A was very confusing. Is there a possibility to dis-consider all the penalties until the explanations were provided?
Sorry, I don't think it can be done. I think I have chosen a little of a wrong way to explain what is needed in task A. Accept my apologies.
Also from next time while setting a contest, please use simple english.
It's okay I guess.
Anyways, Loved the Problemset!
Please explain how to start in task A initially. It only seems like n-1 as answer.
Can anyone please explain me why my code for B was giving TLE Link
Can anyone tell me why my solution for B using gave TLE LINK? I changed my whole implementation beacuse of this.
why i am getting wrong answer in pretest 2 problem B..
89271877 my logic
if there a plank frequency more than(or equal) 8 than ans yes..
if there is 1 plank with freq >= 6 and 2 plank with fre >=2 than ans is yes
if there is a 2 plank with freq>=4 then ans is yes
if there is a plank 1 plank with fre>=4 and 3 plank with frequency more than 2 than answer is yes
if there is a plank 1 plank with fre>=4 and 3 plank with frequency more than 2 than answer is yes
I think in this pt. we only need 2 plank whose freq is greater than 2
it should be 3 becoz the plank whose fre is more than 4 also has freq more than 2
while you are decreasing planks of count <4 you are decreasing mapa2[3]--,it should be mapa2[4]--.
thanks you ....
Great contest! I've enjoyed it, even though, as always, I've spent lots of time with silly errors. Looking for other player's solutions, I came into a program with a swastika commented in the first lines. Looking for other solutions of the same user, I saw that was a constant. The player is OuDaRjA_17o3oo2, and I think he should be banned. Do you know how I could report it?
Many thanks in advance.
OuDaRjA_17o3oo2 has commented a sauvastika and not a swastika. It's a holy symbol in Buddhism and Hinduism
I assume you read it as the Nazi Symbol(which may very well be the case). However, I would urge you to please look up the meaning of swastik and sauvastika in Hinduism and Buddhism.
I would give him the benefit of doubt rather than jumping on conclusions.
I didn't know the meaning of this symbol. You are right, I confused it, I apologize.
Thanks
It still looks wired.
I have a dream!
One day I'll make a div2 round.
There will be no stories in problems!
I think D was similar to this https://leetcode.com/problems/maximal-square/solution/
Nice Problem, but A and B were hard to read for me T_T
My screencast, where you can see video explanations for A-D, watch me fail to rotate a square by 45 degrees, and see me struggle on literally every problem except for C, all in 720p!
Bro, it will be great help if you make tutorial videos for E1 and E2 also.
I don't know how to do them :(
My general idea for E(1) was $$$dp[i][j]$$$ where $$$i$$$ is the string you're at and you removed the $$$j$$$-th character from the last one. But I don't know how to speed up the transitions, even to just $$$O(|s_i|^2)$$$.
Yeah, I think of the same but it will give TLE.
I was thinking about something like this to optimize with prefix sum on sorted(wrt lexographical order) dp[i-1] to calculate dp[i][j] faster.
hey, why do you think the round is bad-balanced? as I can judge by the number of people who solved each task, the balance is nice. also most testers did not find any problems boring
"also most testers did not find any problems boring" I guess you're talking about A-D maybe
one can see how many announcements the team has to just make problem statements clear.
it has no connection with problems' interestingness and balance though.
The problems were good but could have been more concise and clear.
How to do E?
Unclear Problem Statements + Weak Pretests.
Disappointing!
My video solutions to problems (A-D).
I hope you will learn something new. Enjoy watching.
https://youtu.be/NMbqtVdVZqI
For a moment lets ignore story in A
All the problems were good coding problems rather than some mathsy problems. Felt like div 1.5 as E1 was only done by 2 official participants and E2 by none D problem was my favourite one
I'm excited that there are 62 people fail system test because of my hack tests of problem C :p (test 62,63)
that is cruel.
How can I see how many solutions failed after system testing?
You can set the filter as the following picture.
That's why sometimes for Problem A I prefer analyzing test cases rather than reading those massive story lines :3 I was just scrolling and the story continuing :3
89276784 Can someone please explain where I'm going wrong? EDIT: Never mind.
The memory limit on problem D is evil :(
I thought i'd reach 1900 again but, well test 70 had another idea.
I totally agree with you. A solution which is same approach with me passed by 982ms and 200MB, I got TL on 70. The difference between my solution and that one is long long and short, and I've used map<char, vector<ll,ll>> to store input. I think it's unreasonable constraint which give TL to the solution that's complexity is O(NMlog(26)+MN*4), eventhough jury's solution complexity is O(NM). What an unlucky round :(
Maybe the authors could have written a formal description of the problem at the end of each problem statement
.
That's not a valid testcase: The problem statement guarantees that there will be at least two copies of one value.
thanks, i was too careless
Stories are fine, writing wrong problem statements is not.
In problem E it is mentioned several times that we have to calculate number of possible original scrolls. But actually we have to calculate how many ways there are to choose letters to erase.
For example, on test
"correct" answer is 4 because you can delete nothing (1 way) or delete one of the a (3 ways). But there are only 2 possible original scrolls.
yes, you're right. it was clearly mentioned in output section only.
Clearly? Nothing clear about that sentence
Print one integer: the number of ways to get a version of the original from the scroll modulo 10^9+7.
It does not ask you about the number of versions but about the number of ways to get it.
I could have made it clearer I suppose. My bad
That's amazing that you put it to output section, but let's take a look at the problem statements:
To not let the important knowledge slip by Twilight has to look through all variants of the original scroll and find the required one. To estimate the maximum time Twilight may spend on the work she needs to know the number of variants she has to look through.
In other words statements tells you: we need to look through all the original scrolls and find number of variants of those.
More of that, in Russian version we see same wrong statement. So whoever translated the problem, clearly understood it same way as I, which was wrong.
More of that, there were no sample explanation, which probably could show the correct way as well.
So it is not "made it clearer", it is "made it correct".
That would be clear if you explained what ways are different. Should I account for the order in which letters are erased?
I noticed this during the contest when looking at sample input 2 (thankfully quite a bit before starting to write any code), and was a bit confused/disappointed that (at the 90-minute-mark) there had not already been an announcement about this miscommunication. At least my clarification request was answered quickly.
I noticed this during the contest when my code output 4, I looked at dp values and went "yep, that's correct answer", then reread the statement and went "yep, it is mentioned several times".
Samples are part of the statement, of course, but it's not like it is clear by looking at the test what is the answer. It would be ok-ish if there were a sample like the one I mentioned which is so simple that it should be clear what is the right answer. And of course there shouldn't be any places in the statement with clearly wrong meaning. One thing is to have unclear statement, but it's different to have clearly written wrong things.
I am new at codeforces, which blogs can help me with the various information about the site and how should I get started?
Is there a way to find out the distribution of ratings, or in general, an up-to-date ratings post? I see that the “Help” section has a rating section, but that seems outdated.
IMO, I really enjoyed this contest... sad thing is that I figured out problem B and C after the contest...
can someone tell me why my solution of problem B wrong ? It failed on test 11 which is very large.
what was the test 11? my code is also failing in test 11
Size of plank need not to be less than $$$n$$$ , it can be anywhere between $$$1$$$ and $$$1e5$$$. I went through your code and probably that is the mistake . Your accepted code.
thx bro.
Very fast ABC + using different templates + using
printf
andcout
in different problemsWas it a team solving?
Or just a person with bipolar disorder :)
Maybe you are right,but this kind of plagiarism is hard to verify.
Macros differ. Also the tab-size on A&B differs from tab-size on C&D. Idk is this some type of evidence.
I have a request to all. Please don't make fun or roast authors on any issue. Just kindly convey your message to them. These contests are for practice so try to learn as much as you can rather than abusing it.
Didn't find much ponies, but okay :P
https://codeforces.net/contest/1393/submission/89280374
why is this solution taking so long in time.
as i only used static array and linear code.? plus no dynamic objects.
add ios::sync_with_stdio(false) on the begining and try again
well well well, https://codeforces.net/contest/1393/submission/89285827
this is a huge difference !!!!, i never though this would make this much difference.
Man, you seriously need to change your variable names
are they illegal?
Not illegal, but definitely confusing for others when they read your code.
i don't think so,
it so convient except countOf1, countOf2 am using _1 , _2. isn't that easiear and faster to type?
The code in competitive programming is optimized for the writer than for the reader.
This is obviously quite different in software engineering, where you should optimize it for the reader, since many engineers will need to read/understand your code, and some might need to read/understand it in under time pressure to solve a real production issues.
The above variable naming critique does not apply as long as you are disciplined enough that in "real-life programs" you do not (even try to) use them :).
sure thankyou
Didn't find much ponies, but okay :P
would somebody please tell me why i am getting tle on the 11th test case of problem B My submission for the above mentioned question https://codeforces.net/contest/1393/submission/89281935 Thank you in advance
ya its done !!
Figured out it was a silly mistake!!
cost me a lot though
pls help me with problem c, I used binary search in my code I am trying to get maximum distance up to which we do not any issue in allocating , here is the link to the code. https://codeforces.net/contest/1393/submission/89284370
1
10
1 1 3 3 4 4 6 6 6 7
Can anyone tell me my mistake in problem B?
I am counting all pairs of planks that can be used for making rectangles and then checking if those pairs are at least 4. But it gave WA on test 4.
My submission
Sorry for my English.
What if there is a situation where there are , 2 planks of type 1, 2 planks of type 2, 2 planks of type 3 and 2 planks of type 4 , your code will give the output "YES" , but the answer will be "NO" , cause you can't make a square.
When will the ratings change?
If anyone need Detail explanation( not a video tutorial) of B & C
nice blog!
Thanks!
can anyone look at what's wrong with my solution for problem D?
my approach:
u[i][j] Number of cells with the same color above this cell
d[i][j] Number of cells with the same color below this cell
l[i][j] Number of cells with the same color to the left of this cell
r[i][j] Number of cells with the same color to the right of this cell
I find these 4 matrices for each character ('a' — 'z') then for each cell I added this
to the answer considering rhombus is centered at (i, j).
https://codeforces.net/contest/1393/submission/89271632
you dont need to do this for every char. I had the same ideea. https://codeforces.net/contest/1393/submission/89279298
EDIT: i think you are "jumping" over the diagonal characters. Try a 5x5 matrix with same char.
Thanks Got my mistake
i know it doesn't matter , but here is sad story:- I submitted "C" 17 seconds before the contest ended , Got wrong answer in testcase 1, I was clearing my count array upto n, wasn't clearing the last counter. Legit the only difference between my accepted code and the unaccepted one is i<n and i<=n.89277176 89280405 I am consistently getting minus in the last 4-5 contest, today this happens, man this feeling sucks.
well i don't think anyone can help, you are not in a school where teacher can be linient.
I know , just sharing the story, just to feel lighter that's all
Yeah i know how bad it can feel, get off the PC for better.
A Greedy Solution for problem C:
Sort all elements by its frequency (name it to array A).
Let m is the max frequency.
Initialize array B of m empty arrays.
So the i-th of A is added to the (i%m)-th array B.
The answer is size(B[m-1])-1
My Code: 89285457
Can you please explain why this works?
If you want to understand the level of the round, check this is problem https://acm.timus.ru/problem.aspx?space=1&num=1221
Is it just me or, did the explanation of the example test case given in problem statement B change during the contest? After the second event Applejack can build a rectangular storage using planks with lengths 2, 2, 2, 2 and a square storage using planks with lengths 1, 1, 1, 1. became=> After the sixth event Applejack can build a rectangular storage using planks with lengths 2, 2, 2, 2 and a square storage using planks with lengths 1, 1, 1, 1. I ended up wasting a lot of time, trying to make the explanation of the test case make sense to me, but I was not able to! Given that the language of the problems were not clear this time, I thought I was committing a blunder in reading the statement! But, apparently, when I click on the problem statement now, it seems perfectly fine! Did that change during the contest, or am I tripping? The questions were pretty great though, even though I could not even solve one :P
I asked for that, and then they changed it. But they should have given an announcement after this change.
300iq is a serious simp to not reject these shitty statements.
From my point of view the problems where pretty interesting, once understood. It's a shame they were ruined so badly.
I'd agree. The questions (especially problem C) were really nice. However, the problem statements were so overcomplicated with character stories, and the information (needed for solving the problems) was hidden within the stories, which made it slightly uncomfortable for us to solve.
Maybe he's playing the long game, hoping that bad problems will discourage competition, so he can sit on his LGM throne. I call everyone here to join me in the revolution against our tyranical coordinators!
Your problem statements are the best! Short, and cute.
what is the reason for time limit exceeded in my code for problem B ?? link
In the $$$34^{th}$$$ line, add the condition:
if(cnt[x] != 0)
After adding this, your code worked on my computer.
Thank You
I totally missed out this condition
No problem mate.
So did I, until making below lines comment (with /* */) to figure out what the wrong is.
Why ratings aren't updated yet?
.
How to solve problem C using Binary search ?
l = 0, r = n-2 (minimum answer and max answer) and now simulate to find out if "mid" distance can be obtained.
update r and l accordingly.
How do you simulate?
maintain a bool array, where you start placing 1 at positions which are to have a number. i.e if the numbers are 1 2 2 3, and you are at mid = 1, you will start with numbers with highest frequency and go till the lowest one.
it = 0 (starting position)
you placed 2 at 0, bool[0] = 1
it = it + mid + 1;
it = 2 you placed 2 at 2, bool[2] = 1
and so on.
so you have to also keep in check the first non allotted position for it. that way you place all the elements and traverse only once. binary search takes logn, hence complexity is nlogn.
What do you do after?
For example this test case 1 1 1 2 2 3 3 4 4 and mid = 2
I think that there are some details that I'm not getting
I understand that you have 0 0 0 0 0 0 0 0 0 Then with 1: 1 0 0 1 0 0 1 0 0 Then with 2: 1 1 0 1 1 0 1 0 0 But what to do after to avoid having 1 1 1 1 1 1 1 0 0
I don't think you need to avoid 1 1 1 1 1 1 1 0 0 . After you have got 1 1 1 1 1 1 1 0 0 this means answer exists . We can do following : first keep element of greatest frequency (say 'mx') at distance of 'mid' and then go to second number (note they are sorted in order of decreasing frequency) and fill max(f2,mx-1) where f2 is frequency of second number. For 4,4,4,3,3,2,5 and mid = 2 , it will be 4 3 2 4 3 5 4 . In bool array it will be 1 1 1 1 1 1 1 . Hence we can return true . If it was sort of 1 0 1 1 1 1 1 we would have returned false.Am i correct PatronSaint
I am getting WA on test 44 can you please point out my mistake. solution I used binary search and filled bool array with only most frequent numbers
I don't really understand how your check function is meant to work, so I don't know what exactly it does wrong, but I was able to construct a relatively small test case where your program gives the wrong answer. Happy debugging!
Input:
(The correct output is 5; your program prints 0.)
can any one help me with problem D
A blog, that was written got removed by the author, and it spoke about weak test cases in problem B. The submission here 89257174 fails on the following test case :
which should output "YES", as you can see that there are 3 squares possible, but the submission outputs "NO". If this is the case perhaps we might need to rejudge the submissions.
I don't know the author personally or anything, I'm just concerned about the test cases being weak.
UPD: The blog has been reposted. Kindly look into this.
Personally dont think that statements were overcomplicated or difficult to understand. I believe that having less story in the statements would mean having no story at all
Problem C, For the below test case, how to arrange the numbers? The distance between each of the same numbers have to be strictly x. Right?
10
4 4 3 2 4 1 3 4 1 2
Answer for above test case is 2.
The distance has to be AT LEAST x.
One way is 4 3 2 4 1 3 4 1 2 4.
If it's AT LEAST x, then I agree. But, can you kindly point out "AT LEAST" in the problem statement? I read "strictly"(but now that you're saying, strictly was for the smallest greatest distance).
I agree the problem statements were confusing sometimes, but this problem did say "greatest minimum distance". Since the distance is minimum, every other distance is at least as big.
The only place "strictly" appears is in "strictly between the two cakes" — that just means that you don't count the endpoints, only the cakes in between.
Really liked the round! Fun problems and good statements, I had a good time participating.
Looking forward for the next pony round!
Please upload the editorial of this contest!!
Just my opinion -> Problem statements could have been little clear.
I didn't understand question A. Please tell me how to start filling blocks initially. Thanks a lot.
First StoryForces, then weak pretests and now no editorial even after 10 hours. What's wrong with you guys?
The problem statements were too long, I think Mike should change the sites name to storyforces. several participants have pretty bad english background. Before making such long statements and stuff contest writers should think about it. just saying no offence....
Can someone please point out my mistake in my solution for question B?
Link
1 1 1 1 1 1 2 2 2 2 2 2 (six ones, and six twos) will be answer "NO" in your code you have to calculate number of (more than 2), (more than 4), (more than 6), (more than 8)
So why am I getting a runtime error while using vector of size 10001 in the problem B? Link to the code
While using a map is actually accepting the solution? Link to the code
Note: Please check the third line within the function 'void solve()'
Vector size is not enough. Your vector is only 10^4. Change the vector size 100001 (10^5). (Check the problem statement, 1 <= ai <= 10^5 and 1 <= x <= 10^5). I hope this helps you!
when will the tutorials will be made available ?
Can someone explain to me the approach for Question 1? What I did was initially the first player would play the move by coloring all the edge pieces at a gap of 1, afterwards in each subsequent turn the player will complete nth layer and half fill the n-1th layer, counting layers from outside to inside, so each time side of unfilled square will decrease by 2. At last when n-2 >= 1, the last player can fill the remaining part. Have a look at my program 89228494. Any other approach is appreciated.
Hi, let me help you out with this.
Basically in any move, you will fill the outer half-filled circumference and half fill the inner circumference. Outer circumference here means extreme left column + top row + right column + bottom row.
So basically each partial step has: - Input: half-filled outer circumference of color 1(size n square) - Color 2 pony takes her move and.. - Output: half-filled outer circumference of color 2(size n-2 square)
This reduces the net count of the total square by 2 overall (easy to see 4x4, remove the outer circumference to get 2x2, 5x5 to 3x3 and so on..)
NOTE_1: For the very first move, however, we just partially fill the outer circumference. Instead, it can be seen as having an extra outer layer that we completely filled and partially filled the actual layer (let me know if this needs more explanation)
So the answer is (n+2)/2; (added +2 for NOTE_1).
It took me a long while as well, I hope the solution is intuitive ^_^
When we can see the editorials pls??
when do we get the editorial
maybe after the editorial of next round is published!
Mayby they lost fun in writing tutorial because of massive negative feedback.
Wait,Editorials are written after the contest?I use to think they are written before the contest and then posted after.
+1 That's the way it should be.
When will editorial be released for the contest!!
Why is my answer for B resulting in a runtime error? Someone pls help. My code — https://codeforces.net/contest/1393/submission/89245490
Anyone?
If there is no element with frequency >=4 then it2 is not initialized, but dereferenced anyway.
it2->second += 4;
Not able to find the editorial , is it published?
No not now
What's the intended solution for E1? I found that both the time and memory limitations are very tight for a 1e8 algorithm to pass.
I have a $$$O(S*log(S))$$$ solution (where S is the sum of lengths of the words). However, I haven't been able to make it pass the time limit for E2. I suposse the constant factor is not small enough.
The basic idea is to implement a function that allows you to compare pairs $$$(i,j) = i_{th}$$$ string removing its $$$j_{th}$$$ letter. You can do that in $$$O(log(n))$$$ using binary search and hashing (which is more than enough to pass E1). Also, you can do it in $$$O(1)$$$ by computing LCP array and a sparse table for constant time minimum in range queries (I won't go into details, you can think about it).
Using that comparator, sort the pairs belonging to the same word, and then compute dp[i][j]= number of ways of doing the process for the first $$$i$$$ strings if I remove the $$$j_{th}$$$ pair of the last one. It's not that hard to realize that you only care about the sum of a prefix of the dp previous row (because we sorted the elements with our comparator). You can think about the details. Good luck!
Thank you. Finallly passed E1 :)
where is the editorial?
I don't understand why does the problem setter has to make stories, why can't just give the problem statement straightaway, atleast this would rule out the ambiguity in the language and also will save the coordinators to give the announcements in the middle of the contest. I mean if you anyway have to give the crux of problem in the announcements why can't just give it in the actual problem statement itself !
To problem setters: If you love literature so much then publish your stories in a book. Dont create Storyforces
can someone pls tell me what i am doing wrong in problem B.[Here]is my sol.(https://codeforces.net/contest/1393/submission/89328093)
The calculation for n2 is not correct.
int n2=c2-c4,n4=c4-c6,n6=c6-c8,n8=c8;
for the case there are 6 equals and nothing else.I think it is simpler to formulate the if directly on the c* values instead of calc the n* ones, creating another indirection.
Actually ni represents how many different numbers are having frequency i. for example if we are having 6 equal, so we are having only one group with frequency 6, so n2,n4 and n8 will be 0 and n6 will be 1.
Ah, ok. Then you miss the case n6==1 && n4==1 && n2==0, which should output yes.
Please post the editorial
My B failed on system test 20(though pretest passed in contest). Did anyone else had such experience? I still don't know the reason, doing implementation in a different way gave AC.
Where is the editorial?
What about Tutorial ? Isn't it coming this time!!
https://codeforces.net/contest/1393/submission/89251484 Please help in finding the mistake..
I just attempted to solve problem D. I think I solved, and I wondered if anybody solved like me because I don't feel it was the intended solution.
I noticed that if you look at a 45 degree square, it's actually built of a diagonal square of size k on even/odd diagonals, and a diagonal square of size k-1 on the other diagonals. for example:
https://ibb.co/B4nJ3RH
There are two squares here. the 3 by 3 square:
https://ibb.co/rkCfbGc
and the 2 by 2 square:
https://ibb.co/Fz7jfYn
You can then reduce the problem to finding for each cell the largest square in the respective "diagonal matrix" where the cell is the left-most cell (when flipped 45 degrees right, it would be the upper left cell).
Finding the largest square of '1' for each cell where it is the upper left cell is a standard dp problem.
After you do that, you go over the cells and you simply check what's the largest square starting with him, and what is the largest square starting from the cell on its right. If the answers are x and y, the largest cut would be min(x,y+1). In the example above, x is 3 and y is 2, and so the answer is 3.
You don't need multiple dp's because when you do it you check if it's the same char.
The complexity: you build a dp of size n*m, iterate through the matrix once to build it. Then you iterate through the matrix once more and use the dp to get the solution. Space: 2*m*n, Time: O(n*m) with a small constant.
Have you coded this up?
I don't think you see updates on the other comment's thread, so here is my comment again:
It's beautiful! (it actually TLEd in python so I translated to cpp).
Submission (no comments): 89526378
that was very neat!!
If it's correct xD
Hope someone verifies that it worked. I might code it in the next few days but I'm quite busy right now.
i will try code!! (ง'̀-'́)ง
Looking forward to see of it works!
In a few days if you don't reply I think I might try and I'll comment here with he solution.
It's beautiful! (it actually TLEd in python so I translated to cpp).
Submission (no comments): 89526378
EDITORIAL PLEASE Now when it's really time to show your English skills, you are shying away. At least help me upsolve the problems.
If you guys gonna take a long time for the Editorial than at least let us know !! What's the point of not answering and delaying ?
Upload the Editorial pls.. come on' guys..
Its more than 24 hours now .. when will u give the Editorial ? And please use simple english in the editorial
This is insane.
Editorials never take more than 24 hours to be uploaded... What happened?
3Blue1Brown styled visualization of neal's clean code for Problem B
neal's very readable solution for B: 89215119 The corresponding visualization for sample test case:
Link to video if image does not render: https://youtu.be/QqIjqxUWkgQ
Unfortunately, the editorial is taking too long and I had originally thought of posting this there. If you want any other reasonably small test case visualized, let me know. Feedback is welcome.
Editorial?? PS: we don't need the ponies surrounded by fancy english words. What we need is logic to upsolve the problems.
We will post an editorial shortly. Now we are waiting for a good editorial in English. Sorry for delay.
А когда будет опубликован разбор?
We have a ready-made editorial in Russian. When we have a editorial in English, we will post a editorial
Here is my unofficial editorial for problems A-D
https://codeforces.net/blog/entry/81216
We don't want stories this time, in your upcoming Codeforces Round #705 :)