Welcome to Subscribe On Youtube

2805. Custom Interval

Description

Function customInterval

Given a function fn, a number delay and a number period, return a number id. customInterval is a function that should execute the provided function fn at intervals based on a linear pattern defined by the formula delay + period * count. The count in the formula represents the number of times the interval has been executed starting from an initial value of 0.

Function customClearInterval 

Given the id. id is the returned value from the function customInterval. customClearInterval should stop executing provided function fn at intervals.

 

Example 1:

Input: delay = 50, period = 20, cancelTime = 225
Output: [50,120,210]
Explanation: 
const t = performance.now()  
const result = []
        
const fn = () => {
    result.push(Math.floor(performance.now() - t))
}
const id = customInterval(fn, delay, period)
        
setTimeout(() => {
    customClearInterval(id)
}, 225)

50 + 20 * 0 = 50 // 50ms - 1st function call
50 + 20 * 1 = 70 // 50ms + 70ms = 120ms - 2nd function call
50 + 20 * 2 = 90 // 50ms + 70ms + 90ms = 210ms - 3rd function call

Example 2:

Input: delay = 20, period = 20, cancelTime = 150
Output: [20,60,120]
Explanation: 
20 + 20 * 0 = 20 // 20ms - 1st function call
20 + 20 * 1 = 40 // 20ms + 40ms = 60ms - 2nd function call
20 + 20 * 2 = 60 // 20ms + 40ms + 60ms = 120ms - 3rd function call

Example 3:

Input: delay = 100, period = 200, cancelTime = 500
Output: [100,400]
Explanation: 
100 + 200 * 0 = 100 // 100ms - 1st function call
100 + 200 * 1 = 300 // 100ms + 300ms = 400ms - 2nd function call

 

Constraints:

  • 20 <= delay, period <= 250
  • 20 <= cancelTime <= 1000

Solutions

  • const intervalMap = new Map<number, NodeJS.Timeout>();
    
    function customInterval(fn: Function, delay: number, period: number): number {
        let count = 0;
        function recursiveTimeout() {
            intervalMap.set(
                id,
                setTimeout(() => {
                    fn();
                    count++;
                    recursiveTimeout();
                }, delay + period * count),
            );
        }
    
        const id = Date.now();
        recursiveTimeout();
        return id;
    }
    
    function customClearInterval(id: number) {
        if (intervalMap.has(id)) {
            clearTimeout(intervalMap.get(id)!);
            intervalMap.delete(id);
        }
    }
    
    

All Problems

All Solutions