Similar Problems

Similar Problems not available

Design An Ordered Stream - Leetcode Solution

Companies:

LeetCode:  Design An Ordered Stream Leetcode Solution

Difficulty: Easy

Topics: design hash-table array  

Problem Statement:

You are given n length of ordered list of disjoint intervals where each interval is represented by a pair of integers. The ith interval starts from the integer ai and ends at the integer bi. You have to design a stream as follows:

  • You have to sequentially output the integers of each interval in a sorted order.

  • After the output of last integer of each interval, you have to move to the next interval.

  • If the current interval has no more integers to output, then continue on next interval.

  • If the next interval has no integers to output then return empty string.

Write a class OrderedStream to implement above stream.

Solution:

Approach:

We can solve this problem using a simple approach. Here we will use an array of size n to store the integers of the intervals. We will initialize all elements of the array as Null. Then we will iterate through the given list of intervals and update the corresponding elements in the array with the integers of the intervals.

For the output of the Ordered Stream, we will keep track of the last integer that was output for each interval. We will maintain a pointer that points to the lowest index of the elements of the array that is not yet output. Then the output of the stream will be a sequence of the integers that starts from the index pointed by the pointer.

Implementation:

Here is the implementation of the OrderedStream class in Python:

class OrderedStream: def init(self, n: int): self.stream = [None] * n self.pointer = 0

def insert(self, id: int, value: str) -> List[str]:
    self.stream[id-1] = value

    if id - 1 == self.pointer:
        output = []
        while self.pointer < len(self.stream) and self.stream[self.pointer] is not None:
            output.append(self.stream[self.pointer])
            self.pointer += 1
        return output
    else:
        return []

In the constructor of the OrderedStream class, we initialize an array with n elements as None and set the pointer to 0.

In the insert function, we update the elements of the array with the given value for the corresponding id. Then, if the id equals to the current value of the pointer, it means that we can output some integers. So we start outputting the integers from the index pointed by the pointer until it finds a None element in the array. After the output of the integers, we increment the pointer.

If the id is not equal to the pointer, it means that we cannot output any integers at this moment. So we return the empty list.

Time Complexity:

For each insert operation, we output at most n integers from the array. So, the time complexity of the insert function is O(n). The time complexity of the OrderedStream constructor is O(1). Overall, the time complexity of the OrderedStream class is O(n).

Space Complexity:

We are using an array of size n to store the integers of the intervals. So, the space complexity of the OrderedStream class is O(n).

Design An Ordered Stream Solution Code

1#include <iostream>
2#include <string>
3#include <vector>
4
5using namespace std;
6
7class OrderedStream {
8public:
9    OrderedStream(int n) {
10        this->ptr = 1;
11        this->vect.resize(n);
12    }
13    
14    vector<string> insert(int id, string value) {
15        this->vect[id-1] = value;
16        vector<string> result;
17        
18        if(this->ptr == id){
19            while(this->ptr < this->vect.size() && this->vect[this->ptr] != ""){
20                result.push_back(this->vect[this->ptr]);
21                this->ptr++;
22            }
23        }
24        
25        return result;
26    }
27    
28private:
29    int ptr;
30    vector<string> vect;
31};
32
33/**
34 * Your OrderedStream object will be instantiated and called as such:
35 * OrderedStream* obj = new OrderedStream(n);
36 * vector<string> param_1 = obj->insert(id,value);
37 */