ABC170 E
200,000 numbers move around 200,000 times in a set of 200,000 numbers.
In this case, find the minimum value of the "set maximum" for each move problem. Thoughts during the contest
Of course, if we did O(N) for each set for each move, we would TLE.
Is it?
However, as numbers are moved, values other than the minimum may be removed from the "set of maximum values". Example: {1}, {2}, {3} → {1}, {2, 3}, {}
Hmmm, a binary search against a sorted array to find the desired one... no, an add/delete to the array is O(N), so a repeated add/delete attack would make it a TLE.
Lower the cost of adding and deleting by making it a linked list... No, that makes it O(N) to find objects to delete... So make it a bi-directional list and index each object: ????
I see...I tried to make O(1) out of O(N), and it was "if you make that one stand up, this one won't stand up", but should I make it O(logN) in general? I understand the direction.
So what's the specific implementation... hey, someone's using heapq?
I see. The cost of removing elements other than the head of the heap queue is high, but it's okay if we don't remove them; instead, we can add a mechanism to skip reading them.
People away from the set are not removed if they are not at the front of the line.
Remove "the same person" and "the person who is in the other set at the moment" at the time of looking for the next person when the first person is removed.
The "heap queue of maximum score per set" also does not remove old elements when updating
Instead, for each set, record "the time you last updated your maximum score".
When the first element is retrieved for output, discard it if it is old data.
So the code I wrote with reference to it became AC.
impressions
I'm not convinced that this doesn't TLE...
I brought the appropriate AVL tree implementation and replaced it.
→ Code is simplified, but TLE
The order should be O(logN), but the constant times larger?
See 5 from the fastest PyPy implementers
Four people heapq to have individual sets. the number is so large that tree construction is probably avoided because of the overhead. The approach of skipping reads instead of doing deletions seems to be widely used. Only one person was using a set, or hashmap approach. A surprising loophole.
There are 3 segment trees, 1 heapq, and 1 fennic tree to have the largest set of values. The Fennic tree looks interesting, but I'm inclined to be able to use the segment tree for now. Two heapq to store numbers in and out of the set
Find the minimum value in a segment tree
I'm using shift to pack numbers without tuples.
Put in heapq, remove away person at first acquisition
The set of maximum values is also put into heapq
If the person with the smallest value is not the largest value in the set to which the person with the smallest value belongs, skip it.
Is that what you want?
Put in heapq, remove away person at first acquisition
Put the maximum value of the source and destination into the segment tree
His segmented tree code is easy to read.
Representation of a set by a set (set)
The maximum value of a set is normally calculated by max
And that doesn't make it TLE?
I simply imitated it and got a TLE in a test case such as handmade06, which is densely packed in a single set.
If you read carefully, there may be a good twist.
The unique thing about this one is that it only includes the rate, whereas other heapq approaches include the (rate, person ID) pairs.
The maximum value is put in the segment tree.
Sets are represented by heapq
The set of maximal values is a Binary Indexed Tree( Fennic tree ) Efficient updating
Coordinate compression contributes to reducing the size of the tree
based on this
---
This page is auto-translated from /nishio/ABC170 E. If you looks something interesting but the auto-translated English is not good enough to understand it, feel free to let me know at @nishio_en. I'm very happy to spread my thought to non-Japanese readers.