Hello guys I'm trying to be good at counting using combinatorics.
Can anyone recommend some tutorials/problems for me
# | User | Rating |
---|---|---|
1 | tourist | 3993 |
2 | jiangly | 3743 |
3 | orzdevinwang | 3707 |
4 | Radewoosh | 3627 |
5 | jqdai0815 | 3620 |
6 | Benq | 3564 |
7 | Kevin114514 | 3443 |
8 | ksun48 | 3434 |
9 | Rewinding | 3397 |
10 | Um_nik | 3396 |
# | User | Contrib. |
---|---|---|
1 | cry | 167 |
2 | Um_nik | 163 |
3 | maomao90 | 162 |
3 | atcoder_official | 162 |
5 | adamant | 159 |
6 | -is-this-fft- | 158 |
7 | awoo | 156 |
8 | TheScrasse | 154 |
9 | Dominater069 | 153 |
9 | nor | 153 |
Hello guys I'm trying to be good at counting using combinatorics.
Can anyone recommend some tutorials/problems for me
Name |
---|
You can use book named "Maths of choice" by Ivan Morton Niven. It is very useful book.
Thank you, I've got it.
you can use this guide to find resources and problems in it! USACO Guide. find it in : Gold -> Math -> combinatorics.
Thanks Ali
you are welcome.
Counting in combinatorics is as unspecific as loops in programming, but I surmise that the right choice for you is to study combinatorics with some accent on enumerative combinatorics, which is also a vast subject, actually.
The first thing is to gain some fundamental knowledge. I highly recommend working through the book (including exercises) M. Bona, "A walk through Combinatorics", to achieve a more or less good background. Nonetheless, the classical text is R. Stanley's "Enumerative Combinatorics", both volumes.
This is obviously a large portion of work to do and requires systemic study and self-discipline, but the most challenging part, I think, is to get used to a few basic principles (form a basis of your knowledge) and then everything else will be much easier.
Can you suggest any book for number theory.
In the context of competitive programming, one does not really need much apart from prime factorisation of a number, (extended) Euclid's algorithm, and multiplicative function theory (for example, for Möbius inversion and some sieves).
To get used to basic number-theoretic arguments, I recommend going through some olympiad mathematical problems because they are solvable in an elementary setting, unlike most other readings in number theory. It allows one to get a number of ideas, which is also helpful in competitive programming.
Countless olympiad handouts on the Internet.
A. Khurmi, Modern Olympiad Number Theory
P. Bornsztein, X. Caruso, P. Nolin, M. Tibouchi, Cours d'arithmètique (it is really outstanding to me!)
Multiplicative function theory is usually covered comprehensively in books on analytic number theory, see first sections of (increasing of difficulty)
I. M. Vinogradov, Elements of Number Theory (particularly section 2)
T. Apostol, Introduction to analytic number theory (a classical undergraduate course)
H. Iwaniec, E. Kowalski, Analytic Number Theory (this is an excellent graduate book that covers many modern topics, but I do not really recommend reading it without extensive background).
See codechef learning section.
One of the good ways to learn is to solve some problems. You can go to the problemset on codeforces, add combinatorics tag and start solving. If you failed to solve a problem, read the editorial ans maybe you can find a mentioned principle like pigenhole principle. After that you can search about that principle and start to learn it. I recommend using notebook while learning.