Back to School '24
Welcome back everyone! We hope you enjoy the Back to School '24 contest!
The problem setters are
, , and .Special thanks to
, , , , , and for testing and feedback on problems!This contest will be rated for participants with a rating under 2400.
Before the contest date, you may wish to check out the tips and help pages.
You will have 3 hours to complete the contest. After the contest window begins, you may begin at any time. Once you enter the contest, your personal timer will start counting down, and you will be able to submit until 3 hours from when you started, or until the hard deadline (00:00:00 EDT of September 9th), whichever comes first.
After joining the contest, you proceed to the Problems tab to begin.
Here are the parameters of the contest:
- Some problems offer partial marks in the form of subtasks.
- Number of problems: 6, full feedback (you will see the results of your submissions instantly).
- Scoreboard will be hidden, until your window is over. Divulging the contents of the scoreboard to participants who have not finished their window is an offence, the punishments of which are listed below.
- Number of submissions allowed per problem: 50.
- Ties will be broken by the maximum submission time that increased score with no penalties for multiple submissions.
- Problems will be approximately increasing in difficulty. Reading all of the statements is recommended.
- Rated for opening the contest. Being able to read the problems will cause the contest to be rated.
- Checkers: unless otherwise specified, standard.
- It is guaranteed that all problems will be solvable with C++.
We have listed below some advice as well as contest strategies:
- Remove all extra debugging code and/or input prompts from your code before submitting. The judge is very strict — most of the time, it requires your output to match exactly.
- Do not pause program execution at the end. The judging process is automated. You should use stdin / stdout to perform input / output, respectively.
- Python users are recommended to use PyPy 2/3 over Python 2/3 when submitting.
Clarification requests for the contest must be routed through the clarification system provided on DMOJ and not through other channels, including but not limited to Discord and Slack. Furthermore, all clarification requests will be handled the way they normally are in IOI. Note that, in particular, clarification requests must come in the form of yes/no questions.
Due to rampant issues with cheating on contests that have happened recently, any suspicious behaviour during the contest window may result in your rating being impacted negatively. Such behaviour includes but is not limited to:
- Divulging the contents of the scoreboard to participants who have not finished their window.
- Registering for the contest with at least two accounts.
- Participating in the contest with an account that is not your primary account.
- During the contest window, talking about the contest in more detail than answering a yes/no question about whether one participated in the contest. This includes but is not limited to posting spoilers about the contest and public speculation of the contest.
- Attempting to exploit bugs in the platform to subvert the constraints of the contest.
- Attacking the judge infrastructure, other contestants, or contest personnel within or after your window.
Punishments may include performance being unrated or, for more serious infractions, being forcibly ranked at the bottom of the scoreboard.
At the end of the contest, you may comment below to appeal a judging verdict. In the case of appeals, the decision(s) of DMOJ staff is final.
Problems
Problem | Points | AC Rate | Users | Editorials |
---|---|---|---|---|
Back to School '24 P1 - Kicking | 5p | 31.9% | 310 | Editorial |
Back to School '24 P2 - Cheating | 10p | 24.7% | 207 | Editorial |
Back to School '24 P3 - Tournament | 12 | 35.4% | 140 | Editorial |
Back to School '24 P4 - Candidates | 15p | 16.7% | 66 | Editorial |
Back to School '24 P5 - Snitching | 15p | 12.0% | 56 | Editorial |
Back to School '24 P6 - Rex | 20p | 18.0% | 20 | Editorial |
Comments
P5 is nice, but why is the time limit so strict? Very difficult to pass with , especially at 5e5, that's 0.7e9 which is insane for 3s. I see many submits with sqrt solutions timing out, some in contest. I don't think there's any solution which could be cheesed even if . My first sqrt solution was unable to be optimized within the TL despite many attempts until I implemented a different sqrt solution. Would love to know the reasoning behind this decision.
Firstly, I apologize for any difficulties you or others faced with P5. However, I believe the time limit is justifiable for few reasons:
Overall, while I sympathize with you, I stand by the decision. Allowing solutions without the intended time complexity to pass would not have been ideal. Also, I believe this problem can help people understand the power of a good constant factor, as even I was surprised by how fast the algorithm could be. I do not want to clog up the DMOJ comment system with more lengthy explanations, so if you want to discuss further, please join the DMOJ Discord. You can find me there as well. Thanks for participating!
For some additional context for those who are curious, the optimized solution replaced the factor with a factor (using noimi's FastSet/vEB Tree to support
insert
,delete
, andfindMin
in time), which managed to pass with 2.5/3s.noooooooooooo not school :(
Man I love NK
the drought is finally over and the thirst is cured
thank you SO SO SO SO MUCH NK an d876pol
nerd
i concur with this slander of htoshiro, as it is very much needed and necessary given the mental trauma he has inflicted upon me
would've been better if it was called back to spring break
ok lucas
NK and 876pol the 🐐s
thanks for the rated contest!