How can I delete a node from a segment tree?
Clash Royale CLAN TAG#URR8PPP
How can I delete a node from a segment tree?
I'm trying to solve a problem in which I am given a list of numbers and a set of operations. The operations are:
1-print the minimum element of the list and then delete it
2-"p" and "x" are given and the element in position "p" will be given the value "x"
So I thought about using a segment tree, considering that it's easy to determine the minimum of a list and to change an element's value using such a data structure(with the "update" and "query" functions). The problem I encountered was at the deletion of the minimum part. I don't know how could I delete a node from a segment tree so instead I changed the minimum element's value to infinity, sent my code on the website and it didn't get maximum points. If someone can tell what I'm doing wrong and how to solve it I would be really grateful.
@Bogdan Vlad, can you post the whole question, your post isn't clear
– zenwraight
Aug 13 at 3:49
Why use a tree at all? Just use an array
– Mitchel Paulin
Aug 13 at 15:01
@zenwraight The questions is not in english so I will try my best to translate it: You are given a list of numbers on which two types of operations can be done: updating an item (changing its value) and determining, and then deleting, of the minimum element. If the minimum value occurs multiple times in the list, its first occurrence is deleted. It is believed that the elements on the right of the removed element move a position to the left(covers the gap left). I tought that I should solve it with segment trees because I found this problem in the "segment tree" chapter of the website.
– Bogdan Vlad
Aug 13 at 15:51
@Mitchel0022 I need to solve the problem in logarithmic time, which is not possible (as far as I know) using arrays. Sure, you can find the minimum element in logarithmic time using binary search, but then to delete it you would need to move all the elements to the right of the minimum one position to the left to cover the gap and that would take O(n).
– Bogdan Vlad
Aug 13 at 15:54
By clicking "Post Your Answer", you acknowledge that you have read our updated terms of service, privacy policy and cookie policy, and that your continued use of the website is subject to these policies.
That doesn't look like a job for a segment tree.
– m69
Aug 13 at 1:28