From 8d5cc37df980aab7c4be5abec2cdccea319ee797 Mon Sep 17 00:00:00 2001
From: Aananditaa <122295513+Tech-neophyte@users.noreply.github.com>
Date: Mon, 22 Jan 2024 00:27:03 +0530
Subject: [PATCH] day 19-q3 added in python #418
---
.../Tech-neophyte--p.md | 34 +++++++++++++++++++
1 file changed, 34 insertions(+)
create mode 100644 Day-19/q3-Letter Combinations of a Phone Number/Tech-neophyte--p.md
diff --git a/Day-19/q3-Letter Combinations of a Phone Number/Tech-neophyte--p.md b/Day-19/q3-Letter Combinations of a Phone Number/Tech-neophyte--p.md
new file mode 100644
index 00000000..21d276eb
--- /dev/null
+++ b/Day-19/q3-Letter Combinations of a Phone Number/Tech-neophyte--p.md
@@ -0,0 +1,34 @@
+## Approach:
+
1. Initialize a Mapping: Create a dictionary that maps each digit from 2 to 9 to their corresponding letters on a telephone's buttons.
+
2. Base Case: If the input string digits is empty, return an empty list.
+
3. Iteratively make Combinations: Start with an empty combination in a list and iteratively build the combinations by processing each digit in the input string.
+For each existing combination, append each corresponding letter for the current digit, building new combinations.
+
4. Result: Return the generated combinations as the final result.
+## Python code:
+```
+class Solution:
+ def letterCombinations(self, digits: str) -> List[str]:
+ if not digits:
+ return []
+
+ phone_map = {
+ '2': 'abc',
+ '3': 'def',
+ '4': 'ghi',
+ '5': 'jkl',
+ '6': 'mno',
+ '7': 'pqrs',
+ '8': 'tuv',
+ '9': 'wxyz'
+ }
+ combinations=[""]
+ for i in digits:
+ new_comb=[]
+ for j in combinations:
+ for l in phone_map[i]:
+ new_comb.append(j+l)
+ combinations=new_comb
+ return combinations
+
+
+```