Find the mex of the array in o(n) time and constant space complexity; mex = smallest missing element from the array please share your ideas on this tia
# | 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 | 169 |
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 |
Find the mex of the array in o(n) time and constant space complexity; mex = smallest missing element from the array please share your ideas on this tia
Name |
---|
Say n is the size of the array.
Loop through the array:
Let the element you are currently at be a.
If a > n, then just continue
otherwise, swap the values of the current element, and the a(th) element.
The answer will be the the (first index where the index(th) element of the list is not equal to index + 1) + 1.
Note that this is O(1) in space and O(n) time complexity.
In input/output problems (like codeforces, the web where he is asking) you will have to create an array for that, so its O(n) space complexity.
I understand that but i was under the impression that storing the input itself doesnt count towards the space complexity because i have seen editorials where this has happened (i think). Also, mex in O(1) space (by your standards) seems like quite a tall order. I feel like its probably impossible
This assumes all the elements are distinct.
Why do you say so? Notice that in this method, after the initial swaps are done, the value at position i will contain i + 1 if i + 1 exists in the array. Also, if the value at position i does not contain i + 1, then we can be confident that i+1 is not in the original array. So finding the first index where value at index does not equal index + 1 should work no?