We will hold Toyota Programming Contest 2024#1(AtCoder Beginner Contest 337).
- Contest URL: https://atcoder.jp/contests/abc337
- Start Time: http://www.timeanddate.com/worldclock/fixedtime.html?iso=20240120T2100&p1=248
- Duration: 100 minutes
- Writer: leaf1415, MMNMM, ynymxiaolongbao, kyopro_friends, evima
- Tester: cn449, physics0523
- Rated range: ~ 1999
- The point values: 100-200-300-400-425-550-600
We are looking forward to your participation!
Hopefully no googleable problems this time
Me too.
Well done! The score of problem E is only 425 pts.
I hope I can make ABCDE!
So do I.
Yet another TOYOTA Round. Excited.
Hope to make ABCDEF
Hoping to get positive delta!
What's the problem with my solution for Problem E
what's wrong ? is it the approach or the interaction??
you can only ask once and then you need to print the answer
How to solve $$$E$$$?
Hint: Hamming codes
For each bit $$$i$$$ take $$$S_i$$$ to be set of all indices with the bit equal to $$$1$$$. (assuming zero-indexed)
For example n= 8, m is 3:
Submission
Sigh, solved E after the contest, just missed by 33 seconds.
E was discussed long ago on a Chinese Q&A platform (which is completely unrelated to CP and more like Quora) as a brainteaser.
https://www.zhihu.com/question/487696887
It's actually a pretty well-known brain teaser problem afaik: Link1, Link2
If it was original I bet lot less submissions would have happent , doesn't matter learnt something new
I kept getting WA on F. My idea was like :
For each $$$L$$$, find the farthest $$$R$$$ such that number of unique element between range $$$(L, R)$$$ doesn't exceed $$$M$$$. This can be done with two pointers
After that, for each interval $$$(L, R)$$$, get the sum of number of balls that can be put in the box. This can be done by using data structures that supports range sum query (such as fenwick). To count this, I will find the index of the first occurrence of a ball within the range, and then when I move $$$L$$$ forward, I update the occurrence of the next ball with $$$\text{min}(cnt_{ball}, K)$$$
I get WA on 8 test cases. Can anyone help me to spot the flaw in my idea / implementation?
Submission : 49504325
Oh I think I know my mistake. I haven't take into account that a ball with the same color can belong to different boxes when the maximum capacity of the box has been reached
Balls in one color can be in different boxes. Think of this:
You can always fill two boxes with the balls. The answer should be 4.
Yup. This is the case. Thanks
How can I do problem E?I got a WA:
Delete the 20th line of your code. There shouldn't be a newline as you've printed it in the 18th line of your code.
Thanks!
I lost 425 points:(
There's a little bit difficult about problem E is that if $$$N$$$ is a power of $$$2$$$, we can only use $$$\log_2 N$$$ friends, instead of $$$\lfloor \log_2 N \rfloor + 1$$$.
A easy way to think this problem is to seperate with binary bits. But there may be some waste when processing $$$N = 2^x$$$.
Suppose $$$N=16$$$, we can construct:
But now the state
00000
is wasted. We can save it by constructing:Here, the state
0000
just means00001
in the previous version of construction.It doesn't work when $$$N$$$ isn't a power of $$$2$$$, because we cannot determine what does the full-0 state mean then.
Just do
ceil(log2(n))
, you won't trigger precision problems at such a small $$$N$$$.Thanks for pointing this out, got WA because of this
How to solve G?
Root the tree arbitrarily and for each node x calculate how many elements are lesser than x and parent[x] in the subtree of x. (I did this using small to large merging with ordered set)
Now we can do rerooting and keep calculating these values for all the other nodes in another dfs, F(i) will be sum of all the elements smaller than x in the subtree of x, for all nodes x in the subtree.
Code
How to solve D?
You need to maintain the cost in a sliding window, as your window cannot pass through
x
, you can set its cost as a sufficiently large number ($$$10^6$$$ for example), so when your window contains anx
it is automatically out of competition for the smallest cost. Ano
costs nothing and a.
costs $$$1$$$. Then, use prefix sum to calculate the cost for the window.Solved till E, Got to be patient and not jump on the first approach that comes to my mind, For E As at first I was making N(N+1)/2 kind of combinations, and after 4 Wa's I realised it was just 2^x combinations.
B, Does anyone know what's wrong with this? 4 WAs.
ABCABC
should return no, but your code returns yes.Problem B can be solved by sort the original string and check the string obtained by sort whether is equal to the original string.
You can also use the regular expression
/^A*B*C*$/
How to optimize sack + lazy segtree in G ? I thought $$$\mathcal{O}(n \log{n})$$$ would easily pass.
I used segtree merge, which is $$$O(n\log n)$$$, see https://atcoder.jp/contests/abc337/submissions/49506487
btw, can you explain what is "sack + lazy segtree" please?
Thanks for another kind of solution.
Ah, ignore that lazy part, I'm just dumb. For the sack part, I'm using it to calculate how many nodes $$$v$$$ are there in the subtree of node $$$u$$$ such that $$$v < u$$$. And then, I am doing some math in range $$$(\text{tin}_u, \text{tout}_u)$$$. After the math, I can use sweepline algorithm to calculate net values.
Accepted now, https://atcoder.jp/contests/abc337/submissions/49516509
Thank you!
Do you mind to explain how's your approach and why euler tour + segment tree can solve this problem?
I'm glad to. Here is the explanation.
Find a way to calculate the contribution to each $$$f(u)$$$.
For each node $$$u$$$ and it's son $$$v$$$, the path $$$x\to u\to w$$$, where $$$x<u$$$ is inside the subtree of $$$v$$$ and $$$w$$$ is outside the subtree of $$$v$$$, contributes to $$$f(w)$$$.
Also, the path $$$x\to u\to w$$$, where $$$x<u$$$ is outside the subtree of $$$u$$$ and $$$w$$$ is inside the subtree of $$$u$$$, contributes to $$$f(w)$$$.
If we have known how many nodes $$$v$$$ are there in the subtree of node $$$u$$$ such that $$$v<u$$$, for each $$$u\in[n]$$$, then it's all about doing updates on a series of subtrees, which becomes a sequence update problem on the Euler tour.
To calculate how many nodes $$$v$$$ are there in the subtree of node $$$u$$$ such that $$$v<u$$$, I can provide you some methods.
G is same as TTPC2019 M.
Found it after contest and the exactly same code got AC.
Is it intended that $$$O(n \space log^2n)$$$ centroid decomposition solutions receive TLE on problem G? (I was able to get AC using pragmas and some constant optimizations, but why requiring so to solve the problem?)
How did you use centroid decomposition for this problem, I could not figure it out ?
please help on to solve the E
Problems similar to E have appeared in brain teasers before. Click this for reference.
Problem E was Educative. Learned something new.
Hii I have a doubt in problem E. It is asked that the minimum number of friends needed to predict the poisonous juice, so why can't I just take a single friend and make him drink N times ( N different juices).
P.S — Sorry for this lame doubt, I might have misunderstood the question :(
Because we need to know the result on the very next day.Hope this helps.
So you're telling me that only one query is enough for us to know the infected juice, if have the correct distribution of juices.
We will distribute juices among friends in such a way that all the upset friends have exactly 1 juice in common and the friends should be minimum in number.
may I know the reason , why you guys are not providing English editorials? I know I can translate the Japanese version , but still it will be convenient to have English editorials as we had earlier.
@chokudai
How to solve C?
You can use dfs and just print from the starting node which is v[i]==-1 and call dfs(v[i]) and print resulting path .
can we solve $$$G$$$ with centroid decomposition with eular tour ? (I tried but second sample failed :/)
PS: after seeing some peeps I got an ac with similar approach submission
It's easy.
Hi can any explain this problem in E n=5 s="101" I am getting ans 6 but how it is possible and Atcoder giving AC solution
if(s=="111") ans=8 i don't know why this is correct because bottle number 5 only
output n=5 why this distribution is not wrong , if s="111" every friend is ill but in distribution no any such bottle is common in all 3 2 2 4 2 3 4 1 5 8
Please give some insight ???