SDITSAVL - AVL Tree
In this problem you are given two types of query
- Insert an integer to the list.
- Given an integer x, you're about to find an integer k which represent x's index if the list is sorted in ascending order. Note that in this problem we will use 1-based indexing.
As the problem title suggest, this problem intended to be solved using Balanced Binary Search Tree, one of its example is AVL Tree.
Input
The first line contains an integer Q, which denotes how many queries that follows.
The next Q lines will be one of the type queries which follow this format:
- 1 x means insert x to the list.
- 2 x means find x's index if the list is sorted in ascending order.
Output
For each query type 2, print a line containing an integer as the answer or print "Data tidak ada" without quotes if the requested number does not exist in the current list.
Example
Input: 10 1 100 1 74 2 100 2 70 1 152 1 21 1 33 2 100 2 21 2 1 Output: 2 Data tidak ada 4 1 Data tidak ada
Explanation
Until the third query, the current list is {74, 100}. Therefore you must print 2 as 100 is on the first index.
Arriving at the fourth query we haven't added any other number so the list still consists of {74, 100}. Since 70 is not in the list you must print "Data tidak ada" without quotes.
For the last three queries the list looks like this {21, 33, 74, 100, 152} so the answer for the eighth, ninth, and tenth query respectively are 4, 1, and "Data tidak ada".
Constraints
1 ≤ Q ≤ 200000
0 ≤ x ≤ 106
It is guaranteed that all the integers inserted into the list will be distinct.
Notes
There's no guarantee that the input will results a balanced tree i.e. you have to balanced it yourself :)
hide comments
mhasan01:
2020-07-06 21:15:11
Got Accepted using Treap :) |
|
flyingduchman_:
2019-08-07 21:54:25
You need to keep track of the left_child count and right_child count of each node when inserting, rotating the tree to optimize query type 2, otherwise TLE. |
|
mig_143:
2017-07-15 18:42:26
Range of x given in question and in TCs not matching..
|
|
donbox:
2017-06-28 00:26:16
Seems solvable via Segment tree too. Though i am not getting an AC |
Added by: | Louis Arianto |
Date: | 2016-03-23 |
Time limit: | 1s |
Source limit: | 50000B |
Memory limit: | 1536MB |
Cluster: | Cube (Intel G860) |
Languages: | All except: ASM64 GOSU JS-MONKEY |
Resource: | Praktikum Struktur Data D 2015 - Institut Teknologi Sepuluh Nopember |