Hi. Today i tried to solve 598F - Длина разреза. There is an editorial. However as a pupil i did not get anything from that. So any idea would be appreciated how to solve it. Thank you in advance.
# | User | Rating |
---|---|---|
1 | tourist | 3985 |
2 | jiangly | 3814 |
3 | jqdai0815 | 3682 |
4 | Benq | 3529 |
5 | orzdevinwang | 3526 |
6 | ksun48 | 3517 |
7 | Radewoosh | 3410 |
8 | hos.lyric | 3399 |
9 | ecnerwala | 3392 |
9 | Um_nik | 3392 |
# | User | Contrib. |
---|---|---|
1 | cry | 169 |
2 | maomao90 | 162 |
2 | Um_nik | 162 |
4 | atcoder_official | 161 |
5 | djm03178 | 158 |
6 | -is-this-fft- | 157 |
7 | adamant | 155 |
8 | awoo | 154 |
8 | Dominater069 | 154 |
10 | luogu_official | 150 |
Hi. Today i tried to solve 598F - Длина разреза. There is an editorial. However as a pupil i did not get anything from that. So any idea would be appreciated how to solve it. Thank you in advance.
Name |
---|
We basically need to find the length of the common part between a line AB and a polygon P.
First for each line XY in polygon P, compute the intersection point between AB and XY.
These are the points where the line either enters the polygon or leaves the polygon.
Sort these points according to their order on the line (based on their distance from A or distance from B).
Your answer is the sum of distance between each Entering point and its immediate next Leaving Point in this order.
This is the basic idea. But the implementation can be quite tricky, since vertex points may occur twice as intersection points and 180-degree angles are allowed in the input. If you can't figure it out on your own, just look into someone else's code.