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 + + +```