How to get started for Competitive Programming
Every time when you ask someone good about how to practice, he/she will reply to you to “solve a lot of problems” and that’s true, there’s no other way. Anyway, I’ve thought about it and actually I’m able to tell a bit more. I know some people; I’ve seen many people practicing (including me) and I have an opinion.
Many people practice in some organized way. High schools organize IOI/OI training contests every Saturday, universities organize ICPC training contests once a week, people try on their own to solve three problems each day, websites host rounds, and so on. Here’s a secret: it’s a sh*t. Yep, that’s true. If you want to be really good and to make it happen you compete in training once a week, you do it only to be able to make excuses “but I’m training so hard” when you see no progress.
Every really good person gave a part of their life to CP. And I don’t mean giving up Saturday parties or having no friends, I kind of mean the part of their minds. You have to really want to get better and find real pleasure in practicing and watching your progress. It also means catching yourself thinking about various problems or seeing algorithmic interpretations in many aspects of real life.
You should practice every time when you have an idea “oh, I’d solve some problem”, “oh, it’d be good to practice a bit now” or “oh, it’d be cool to solve every problem on this website, let’s start”. Here’s a trick: if you really want to be good, you’ll have a lot of such ideas. If you don’t have them and you want to just practice weekly, then better go and reconsider if you really want to be better.
Do you think that you are bad at combinatorics? Good, you see your weaknesses, go solve some such problems.
Do you want to simply solve a few problems? Great, go and solve them as long as they are challenging for you. Or you want to solve every problem from some problem set (still can be a challenge for you). Or you want to upsolve a whole round (still can be a challenge for you). Or you want to have more problems solved on Codeforces than your friend (still can be a challenge for you). Or because of any other reason, but still, don’t solve the easiest problems on Codeforces and expect to become good.
Do you want to participate in a virtual round? Sure, go and do this. Don’t do this if you are sure that you’d solve them. Do this if you want to check if you’d win that round/be better than your friend/something. Challenges, remember? But don’t get me wrong, for example, if you are already quite strong and you want to read (or even participate) the problems from div3, which is definitely below your level — it’s ok if it’s a sign that you are curious about problems and it’s interesting for you.
Do you really want to get better and compete virtually in two 5-hour contests in a row? Great, go and practice.
Want to go and participate in a training organized by your university? Of course, great idea — rivalry, some stress, fun with other people. If you are really practicing and trying to get better, the weekly training with your schoolmates/university/teammates will become a nice event for you, but don’t depend on them. Also, practicing with your ACM team is a way to create a better team — you have to know your weaknesses and strengths and learn how to cooperate. To make your team better at solving problems when you already know how to cooperate, you have to make yourself better at solving problems.
Do you want to skip a training organized by the university and meet your friends/read a book/play some games? Sure, if you don’t feel like practicing, then don’t force yourself. If you really want to practice and become strong, you’ll for sure compete in this contest virtually or something, don’t force yourself, just really feel a need to practice. You can’t rush art, right?
One more time: you really have to have CP in your mind. After solving a problem, it doesn’t mean that it’s gone and you have to forget about it. Maybe you’ll find yourself thinking about some interesting aspects of some task and you’ll invent a harder one.
I don’t know what’s more to say. Don’t give up. With the right attitude, if you can’t solve a problem that is really interesting/important for you, you’ll try for a few days — the pleasure and self-satisfaction after solving a problem for a few days with success is one of the best feelings.
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”.
So yeah, that’s my opinion. Let CP get into your mind and find a true desire to practice. Don’t try to force yourself to practice in an organized way.
I know that this blog may discourage some people, but they wouldn’t go far with such an attitude. I also think that it can help people with real potential to become somebody really strong and that’s why I wrote it.
If any other top-rated coder wants to share his/her way or just point the differences — that’s great.