Given an interval [L, R]. Given an array of intervals in the form of Li and Ri. How many minimum intervals required to cover the range [L, R]? Intervals can overlap with each other. L>=1 && R<=1e5 Li>=1 && Ri<=1e5 The size of the array <= 1e5
| # | User | Rating |
|---|---|---|
| 1 | Benq | 3792 |
| 2 | VivaciousAubergine | 3647 |
| 3 | Kevin114514 | 3611 |
| 4 | jiangly | 3583 |
| 5 | strapple | 3515 |
| 6 | tourist | 3470 |
| 7 | Radewoosh | 3415 |
| 8 | Um_nik | 3376 |
| 9 | maroonrk | 3361 |
| 10 | XVIII | 3345 |
| # | User | Contrib. |
|---|---|---|
| 1 | Qingyu | 162 |
| 2 | adamant | 148 |
| 3 | Um_nik | 146 |
| 4 | Dominater069 | 143 |
| 5 | errorgorn | 141 |
| 6 | cry | 138 |
| 7 | Proof_by_QED | 136 |
| 8 | YuukiS | 135 |
| 9 | chromate00 | 134 |
| 10 | soullless | 133 |
Given an interval [L, R]. Given an array of intervals in the form of Li and Ri. How many minimum intervals required to cover the range [L, R]? Intervals can overlap with each other. L>=1 && R<=1e5 Li>=1 && Ri<=1e5 The size of the array <= 1e5
| Name |
|---|



Auto comment: topic has been updated by Finding_Infinity (previous revision, new revision, compare).
I think it can be done by sorting and pointers:
Sort the intervals according to 'r' and if two intervals have same 'r' choose the interval having max diff of |r-l|. After that remove(ignore) all intervals having same 'r' except the one which have maximum difference of |r-l|.
Now starting from any interval having r>=R which intersects R, move towards left up_to and also make a variable eg: maxL , which stores the maximum l you ever reached. If maxL becomes smaller than the current interval's l then update maxL and increase the count.
Stop when you reach the desired L, and print the count.
I think this should work.
initially , count = 1.
Start increasing count when you've come the left of R.