Hi all,

The first contest of the 2017-2018 USACO season will be running from December 15th to December 18th. Good luck to everyone as we start our season! Please wait until the contest is over for everyone before discussing problems here.

Update 1: The contest is now live!

How to register on this contest?

if you make an account, you are automatically registered.

They say "pipe stdin / pipe stdout", but actually it's not. File names for Platinum :

It'd be great if someone share the filenames for other divisions too.

This has been resolved.

EDIT: I'm passing along a request from the contest admin, who would also like to request that for any sorts of technical issues, to contact directly as opposed to posting about them on social media. The admin isn't actively tracking all forms of social media where these issues might be discussed but will respond to any direct queries, and hopes that contestants who notice issues will escalate them properly so everyone can have a smooth contest.

Auto comment: topic has been updated by xiaowuc1 (previous revision, new revision, compare).UPD: found out

Is there a way to submit a solution after I have finished my window (to check if a solution is correct) or I must wait until the whole contest finishes?

You need to wait until the entire contest is finished. However, you can still view the problem statements.

Hey, can you post the link to the problem statements?

How to solve G2: Barn Painting?

DP On Trees, DP[i][j] is how many diferent coloring can we generate in the subtree of i if we give i the color j , dp[i][j] *= (dp[x][(j+1)%3] + dp[x][(j+2)%3]) , x is a son of i, do this for every x son of i, take care of the nodes who already have a color. Code

I have a question about how already colored nodes are handled.

For example, if node 6 is a leaf node that is colored 2

According to your code I think something like this would happen:

(changed to 1-based index for simplicity)

dp[1][6] = 1 dp[2][6] = 1 dp[3][6] = 1

Wouldn't it conceptually make sense that

dp[1][6] = 0 dp[2][6] = 1 dp[3][6] = 0

For some reason the above one seems to work even though it doesn't make much sense

if c[6] == 2 , then "if(c[x] !=i && c[x] != -1)" guarantee that dp[1][6] = dp[3][6] = 0 , am i missing something here?

Thanks, you are right. I wrote a very similar code but am getting WA. I am trying to find out how our codes differ.

Edit: Found the bug. I spend 3 hours looking for some type of logic error but it turns out I just wrote '&' instead of '%'. I guess the smallest things count :P

Here's my Java solution for reference as well.

How to solve Platinum P3. Greedy?

Simply binary search on the first cow which does not get a gift.

Find a prefix such that each cow in that prefix will enter the queue inside the prefix. If this happens all remaining cows will not reach the front of the queue. You need to find such smallest prefix. I solved it in O(n log n) because I use max-segment tree but it can be solved with two sweeps in O(n) I believe.

Alternatively, you can find this prefix by noticing that two cows jumping to position

iare as good as a cow jumping to positioniand a cow jumping to positioni- 1.So you can create a set with all positions {0, ...,

n- 1}, and then go through the cows one by one, for each cow removing the last position no greater thenn- 1 -c_{i}. Once you remove 0 you have found such a prefix. (Because if you removed positions 0 throughk- 1 and notk, you havekcows in your prefix all jumping to a position less thank.)How to solve Plat 1 ?

Suffix Array + LCP Array

Can you elaborate?

I used hashing to sort the suffixes. Link

I am completely speechless that this actually works.

What's wrong with this approach?

I guess it would be better to say "in awe" :)

Do you mean it's too slow? Computers are pretty fast, right?

No, not at all. I mean I'm surprised that I've never seen anyone implement it like this before! It's really great.

So ekzhang, how did you solve this problem?

@vb7401: I used O(N log N) suffix array and LCP array.

I have a solution with suffix automaton.

Can you elaborate?

I also has automaton solution. First you build automaton for string s_1 + 0 + s_2 + 1 + ... + s_n + (n — 1)

Now for each vertex you want to know if there is only 1 number labeled edge reachable from it not using number labeled edges. If yes all string corresponding to this vertex are unique for that word.

When will editorial be out? Edit: Editorial is out

How to solve Plat. 2 ?

DP[X][Y][4] — is cell (X,Y) reachable from B if the player was last is one of the 4 adjacent cells. Then the transition can be done by seeing if we can push the box to the four directions (cells of type (X+dirx[p],Y+diry[p])). That's possible if from the current player's cell we can reach cell (X-dirx[p],Y-diry[p]) without stepping on the cell with the box (cell (X, Y)). Well this is equivalent to checking if these two cells are in the same biconnected component (I'm not sure if that's the correct name, but I mean components such that by removing each vertex the component remains connected). During the contest I wasn't able to pass the problem as I implement Tarjan's algorithm in a wrong way, but I'm almost certain this solution should work.

That was what I tried too, I tried to use block-cut tree to check if it is possible to reach but, unhappily I received MLE (Maybe the implementation was wrong)

I used block-cut tree and it worked perfectly :)

actually checking if you can go from a node to another without passing through a particular node can be done with a simple dfs tree(http://wcipeg.com/problem/coi06p2). (I ragequit after getting a WA so if something sounds wrong please tell me)

AC on Cases 1-4 for "pushabox"

My observation is that if a box is not at an articulation point, Bessie can move to any side of it, given that the side is not a '#' character; however, if the box is an articulation point, two sides must be in the same biconnected component if Bessie were to travel between them. Is this observation incorrect, or is my implementation faulty in some way?

Anyone have any idea when the results will be announced?

"The USACO December 2017 contest has just ended. Results are being tabulated and will be posted soon." — On the front page as of now.

I assume that means within a day.

Historically, it has been a bit longer. Closer to 4-7 days.

Huh, you're right.

Seems like usaco "soon" is not codeforces "soon"

Results are up. But why is there not complete results for Platinum? They have always released complete results except for Open round...

What do you mean complete results. Do you mean it only shows contestants >=750?

I'm not sure why they changed format, you can email bcdean@clemson.edu for these questions.

Usually they release scores of all pre-college Platinum contestants in monthly contest. This time they only release result of top scorers, or >= 628

Has anyone emailed USACO asking what is up with the new score displaying?

To anyone who hasn't seen it yet, you can now check your rank in the contest by logging in to usaco.org and going to the December 2017 contest page.

Why does USACO consider the last submission to find the result? I got a good score first and then made some changes and score reduced and the time got over. I didn't know they checked as per the last submission. :(

Pretty sure I just failed by a one line bug