Plz help me in solving this problem?
# | User | Rating |
---|---|---|
1 | jiangly | 4039 |
2 | tourist | 3841 |
3 | jqdai0815 | 3682 |
4 | ksun48 | 3590 |
5 | ecnerwala | 3542 |
6 | Benq | 3535 |
7 | orzdevinwang | 3526 |
8 | gamegame | 3477 |
9 | heuristica | 3357 |
10 | Radewoosh | 3355 |
# | User | Contrib. |
---|---|---|
1 | cry | 168 |
2 | -is-this-fft- | 165 |
3 | atcoder_official | 160 |
3 | Um_nik | 160 |
5 | djm03178 | 158 |
6 | Dominater069 | 156 |
7 | adamant | 153 |
8 | luogu_official | 152 |
9 | awoo | 151 |
10 | TheScrasse | 147 |
Plz help me in solving this problem?
Name |
---|
link to problem?
It's a greedy and brute force problem.
For any given message order, process the packets greedily. You should repeat the following process for each packet.
The minimum needed buffer size for the message order will be the maximum among all the buffer sizes at Step 3.
Since N ≤ 5, you can try out all possible orderings of the messages. Every packet will be added only once to the buffer and removed only once, so the process is linear for each ordering, hence the total complexity will be O(M * N!).
If possible can you plz explain me with code, it will be very helpful to me.
Here is the code if you want to check some implementation details, but I suggest you code it and submit it yourself until you get AC.
C++ Code