Блог пользователя Dominater069

Автор Dominater069, 4 месяца назад, По-английски

Recently, I got a request asking me to write down my thought process while solving questions. So, here is the promised blog.

I would like to thank IceKnight1093, qwexd, Sana, Everule and NovusStellachan for proof reading and suggesting edits in the blog. Special thanks to satyam343 for discussing most of the blog with me.

1. Overview

The blog contains my solutions to $$$7$$$ problems in a wide range of ratings, starting from $$$1200$$$ all the way upto $$$2700$$$. Each problem has a step-by-step solution and you can notice how there are no large jumps in logic, but everything comes naturally. I do not claim that this is always possible in each problem, however I solve majority of CF problems in such a manner.

There are certainly other high rated people who will have completely different methods of solving. However, this is about what works for me. There are some meta ideas taken from parts of the solution and listed at the end in a "What can we learn?" section. I hope the blog is useful for you.

2. Some General Question Solving Strategies

Here is a non-exhaustive list of techniques that are useful to keep in mind. These are internalized by most experienced participants already but maybe it helps you.

  • Figuring out the Nature of an Optimal Solution. One of the most important thing in problems imo.

  • Solving subtasks of the original problem and then trying to extend/generalize your solution.

  • Fixing a parameter and then trying to maximise the result with respect to that fixed parameter.

  • Finding necessary and sufficient conditions. Sometimes, your necessary conditions themselves become sufficient, or vice versa.

  • Identifying Lower and Upper bounds, and constructing them.

  • Reducing a problem into smaller subproblems, commonly used with Dynamic Programming or Inductive Proofs.

  • Considering the Decision Version of the Problem instead. Especially useful in Counting problems, where you need to count number of good subsequences for example.

  • Formalizing the Problem

3. Questions and Solutions Section

Question 1. 1979C - Earning on Bets

Step 1
Step 2
What can we learn?

Question 2. 1987D - World is Mine

General Idea
Step 1
Step 2
Step 3
Step 4
What can we learn?
Similiar Problems

Question 3. 1977C - Nikita and LCM

Step 1
Step 2
What can we learn?

Question 4. 1889B - Doremy's Connecting Plan

Step 1
Step 2
Step 3
What can we learn?

Question 5. 2002D1 - DFS Checker (Easy Version)

Step 1
Step 2
Additional Note
Implementation
What can we learn?

Question 6. 1930E - 2..3...4.... Wonderful! Wonderful!

Step 1
Step 2
Step 3
What can we learn?

Question 7. 2003E1 - Turtle and Inversions (Easy Version)

Disclaimer : My solution differs from the editorial completely. You can read the editorial for their approach. I will present mine. Try to extend to the hard version of the problem from this.

Subproblem
Subproblem Step 1
Subproblem Step 2
Subproblem Step 3
Step 4
Additional Note
Hint 1 of Hard Version
Hint 2 of Hard Version
What can we learn?

4. About Stress Testing

Something which a lot of low rated participants do wrong : They don't stress test.

There have even been contests where I stress tested $$$3$$$ problems. I tend to make a lot of errors while writing code and it is not easy to always catch those errors with manually reading or debugging. Learning the skill of stress testing is insanely useful (and you don't need any tools for it, I do it all in the same piece of code without taking much time).

This was the first problem (I think) that i had stress tested during contest : 1854A1 - Dual (Easy Version) I was still done within $$$12$$$ minutes and it took me less than $$$5$$$ mins to stress test, and fix my bug (this is an easy example though as I didn't have to write a brute). My bug only occurred when all elements of the array were equal and negative, I don't think I would manually be able to catch that.

1987F1 - Interesting Problem (Easy Version) In the initial submission to this problem, I missed so many if-cases. I was very careless. But i managed to stress test and avoid more WAs. I think it took me 3 — 4 iterations of finding bug with stress test, fixing them and then again running stress test before my code was actually correct.

I highly recommend stress testing for you. It is simpler than you think : all you need is a brute function, and a generator. I usually replace my input function with a generator, and use a lambda function for the brute. It takes barely $$$5$$$ minutes to setup for most problems.

  • Проголосовать: нравится
  • +263
  • Проголосовать: не нравится

»
4 месяца назад, # |
  Проголосовать: нравится +2 Проголосовать: не нравится

Dominater069 orz Thanks for the CodeChef rounds and for writing comments in your solutions. I hope to see more educational blogs and contests from you.

»
4 месяца назад, # |
  Проголосовать: нравится -36 Проголосовать: не нравится

bro stop wasting your times writing this blogs and instead practice some problems.
we are desperately waiting for first LGM from bharat

»
4 месяца назад, # |
  Проголосовать: нравится +27 Проголосовать: не нравится

Thanks for the blog. Also congrats Dominater069 on reaching 2800+ and LGM performance this contest.

»
4 месяца назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

thanks

»
4 месяца назад, # |
  Проголосовать: нравится +5 Проголосовать: не нравится

Thanks for the great blog! I think it's worth mention that writing a few example on paper and making conjecture/observation based on them is also extremely useful and used a lot when solving ad-hoc problems.

»
4 месяца назад, # |
  Проголосовать: нравится +52 Проголосовать: не нравится

I guess Radewoosh was incorrect on this one /j

Also, one last tip: I've noticed it observing all the top people on Codeforces/Atcoder. None of them uses the word "question" instead of "problem"/"task". So don't do it. You won't progress if you'll keep calling problems "questions"
  • »
    »
    4 месяца назад, # ^ |
      Проголосовать: нравится +97 Проголосовать: не нравится

    It is intentionally done due to that :)

    If you look deeper into the blog, i always mention "problems" (because i was lazy to change them) only the headings have questions

»
4 месяца назад, # |
  Проголосовать: нравится +117 Проголосовать: не нравится

God, it's like staring in the mirror...

»
4 месяца назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

this strategies are really very helpful

»
4 месяца назад, # |
  Проголосовать: нравится +3 Проголосовать: не нравится

can you elaborate what you mean by "Nature of an Optimal Solution" ?

  • »
    »
    4 месяца назад, # ^ |
      Проголосовать: нравится +3 Проголосовать: не нравится

    what are some properties that at least one best solution of the problem may contain?

    for example, read the solution to q4 and its what can we learn section

»
4 месяца назад, # |
  Проголосовать: нравится +4 Проголосовать: не нравится
Typo for Q1

Other than that, this is a nice blog as I can see how a top competitor approaches a problem. Please do more of these write ups!

»
4 месяца назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

It would be nice if someone added this blog to the catalog

»
4 месяца назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

That's of great help! Hope it can be read by more!

»
4 месяца назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

If I encounter a new thing while solving a problem, then how do I learn that topic and questions related to that to solve for getting better at it? For e.g. Graph or DP.

»
4 месяца назад, # |
  Проголосовать: нравится +13 Проголосовать: не нравится

Thank you for your helpful blog! I still have a questions(perhaps there are many others who have the same question): how do you complete a stress test in 5 minutes? Can you explain it in more detail?

»
4 месяца назад, # |
Rev. 5   Проголосовать: нравится +2 Проголосовать: не нравится

“Great work!@Dominater069 I really appreciate the valuable time you put into this blog. I believe that combining all these with other great blogs in the catalog will help us improve to a certain extent.”

»
4 месяца назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

"(You can do it the other way too, for example dp(i,j)= the maximum value of |x| under the constraint that $$$∑freq_x$$$ is j ).

If you understood the question, transitions are pretty simple to come up with(no its not) and are left as an exercise."

How? Don't we need the value of the dp ( |x| ) to do the transitions?

»
4 месяца назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

Thanks a lot for the tips, also where can I find a more detailed guide for stress testing? thanks again :)

»
4 месяца назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

thanks , we need more of this !

»
4 месяца назад, # |
Rev. 2   Проголосовать: нравится 0 Проголосовать: не нравится

I see most of your explanations are heavily relied on mathematics(algebra). If you don't mind can you please suggest us the topics that we need to master in mathematics in order to come up and write the solutions as you did in the blog. Thank you!!

»
2 месяца назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

Thanks for this really helpful blog!

»
2 месяца назад, # |
  Проголосовать: нравится +8 Проголосовать: не нравится

Waiting for, How to Create Questions Dominater069 Version

»
2 месяца назад, # |
  Проголосовать: нравится +5 Проголосовать: не нравится

Please write a blog about stress testing