2694. Event Emitter LeetCode Solution
In this guide, you will get 2694. Event Emitter LeetCode Solution with the best time and space complexity. The solution to Event Emitter problem is provided in various programming languages like C++, Java, and Python. This will be helpful for you if you are preparing for placements, hackathons, interviews, or practice purposes. The solutions provided here are very easy to follow and include detailed explanations.
Table of Contents
- Problem Statement
- Complexity Analysis
- Event Emitter solution in C++
- Event Emitter solution in Java
- Event Emitter solution in Python
- Additional Resources

Problem Statement of Event Emitter
Design an EventEmitter class. This interface is similar (but with some differences) to the one found in Node.js or the Event Target interface of the DOM. The EventEmitter should allow for subscribing to events and emitting them.
Your EventEmitter class should have the following two methods:
subscribe – This method takes in two arguments: the name of an event as a string and a callback function. This callback function will later be called when the event is emitted.
An event should be able to have multiple listeners for the same event. When emitting an event with multiple callbacks, each should be called in the order in which they were subscribed. An array of results should be returned. You can assume no callbacks passed to subscribe are referentially identical.
The subscribe method should also return an object with an unsubscribe method that enables the user to unsubscribe. When it is called, the callback should be removed from the list of subscriptions and undefined should be returned.
emit – This method takes in two arguments: the name of an event as a string and an optional array of arguments that will be passed to the callback(s). If there are no callbacks subscribed to the given event, return an empty array. Otherwise, return an array of the results of all callback calls in the order they were subscribed.
Example 1:
Input:
actions = [“EventEmitter”, “emit”, “subscribe”, “subscribe”, “emit”],
values = [[], [“firstEvent”], [“firstEvent”, “function cb1() { return 5; }”], [“firstEvent”, “function cb1() { return 6; }”], [“firstEvent”]]
Output: [[],[“emitted”,[]],[“subscribed”],[“subscribed”],[“emitted”,[5,6]]]
Explanation:
const emitter = new EventEmitter();
emitter.emit(“firstEvent”); // [], no callback are subscribed yet
emitter.subscribe(“firstEvent”, function cb1() { return 5; });
emitter.subscribe(“firstEvent”, function cb2() { return 6; });
emitter.emit(“firstEvent”); // [5, 6], returns the output of cb1 and cb2
Example 2:
Input:
actions = [“EventEmitter”, “subscribe”, “emit”, “emit”],
values = [[], [“firstEvent”, “function cb1(…args) { return args.join(‘,’); }”], [“firstEvent”, [1,2,3]], [“firstEvent”, [3,4,6]]]
Output: [[],[“subscribed”],[“emitted”,[“1,2,3”]],[“emitted”,[“3,4,6”]]]
Explanation: Note that the emit method should be able to accept an OPTIONAL array of arguments.
const emitter = new EventEmitter();
emitter.subscribe(“firstEvent, function cb1(…args) { return args.join(‘,’); });
emitter.emit(“firstEvent”, [1, 2, 3]); // [“1,2,3”]
emitter.emit(“firstEvent”, [3, 4, 6]); // [“3,4,6”]
Example 3:
Input:
actions = [“EventEmitter”, “subscribe”, “emit”, “unsubscribe”, “emit”],
values = [[], [“firstEvent”, “(…args) => args.join(‘,’)”], [“firstEvent”, [1,2,3]], [0], [“firstEvent”, [4,5,6]]]
Output: [[],[“subscribed”],[“emitted”,[“1,2,3”]],[“unsubscribed”,0],[“emitted”,[]]]
Explanation:
const emitter = new EventEmitter();
const sub = emitter.subscribe(“firstEvent”, (…args) => args.join(‘,’));
emitter.emit(“firstEvent”, [1, 2, 3]); // [“1,2,3”]
sub.unsubscribe(); // undefined
emitter.emit(“firstEvent”, [4, 5, 6]); // [], there are no subscriptions
Example 4:
Input:
actions = [“EventEmitter”, “subscribe”, “subscribe”, “unsubscribe”, “emit”],
values = [[], [“firstEvent”, “x => x + 1”], [“firstEvent”, “x => x + 2”], [0], [“firstEvent”, [5]]]
Output: [[],[“subscribed”],[“subscribed”],[“unsubscribed”,0],[“emitted”,[7]]]
Explanation:
const emitter = new EventEmitter();
const sub1 = emitter.subscribe(“firstEvent”, x => x + 1);
const sub2 = emitter.subscribe(“firstEvent”, x => x + 2);
sub1.unsubscribe(); // undefined
emitter.emit(“firstEvent”, [5]); // [7]
Constraints:
1 <= actions.length <= 10
values.length === actions.length
All test cases are valid, e.g. you don't need to handle scenarios when unsubscribing from a non-existing subscription.
There are only 4 different actions: EventEmitter, emit, subscribe, and unsubscribe.
The EventEmitter action doesn't take any arguments.
The emit action takes between either 1 or 2 arguments. The first argument is the name of the event we want to emit, and the 2nd argument is passed to the callback functions.
The subscribe action takes 2 arguments, where the first one is the event name and the second is the callback function.
The unsubscribe action takes one argument, which is the 0-indexed order of the subscription made before.
Complexity Analysis
- Time Complexity: Google AdSense
- Space Complexity: Google Analytics
2694. Event Emitter LeetCode Solution in C++
type Callback = (...args: any[]) => any;
type Subscription = {
unsubscribe: () => void;
};
class EventEmitter {
private eventToCallbacks: Map<string, Callback[]>;
constructor() {
this.eventToCallbacks = new Map();
}
subscribe(eventName: string, callback: Callback): Subscription {
if (!this.eventToCallbacks.has(eventName))
this.eventToCallbacks.set(eventName, []);
const callbacks = this.eventToCallbacks.get(eventName);
callbacks?.push(callback);
return {
unsubscribe: () => {
const index = callbacks?.indexOf(callback);
if (index !== undefined && index !== -1) {
callbacks?.splice(index, 1);
}
},
};
}
emit(eventName: string, args: any[] = []): any[] {
const callbacks = this.eventToCallbacks.get(eventName);
if (callbacks === undefined) {
return [];
}
return callbacks.map((callback) => callback(...args));
}
}
/* code provided by PROGIEZ */
2694. Event Emitter LeetCode Solution in Java
N/A
// code provided by PROGIEZ
2694. Event Emitter LeetCode Solution in Python
N/A
# code by PROGIEZ
Additional Resources
- Explore all LeetCode problem solutions at Progiez here
- Explore all problems on LeetCode website here
Happy Coding! Keep following PROGIEZ for more updates and solutions.