Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,959 questions

51,901 answers

573 users

How to group Anagrams from a list of strings in Python

1 Answer

0 votes
from collections import defaultdict

def group_anagrams(strs):
    anagram_map = defaultdict(list)

    for str in strs:
        sorted_str = ''.join(sorted(str))  # Sort characters in string
        anagram_map[sorted_str].append(str)  # Group by sorted string

    return list(anagram_map.values())

input_words = ["eat", "tea", "tan", "ate", "nat", "bat", "tae"]
grouped_anagrams = group_anagrams(input_words)

for group in grouped_anagrams:
    print(group)



'''
run:

['eat', 'tea', 'ate', 'tae']
['tan', 'nat']
['bat']

'''

 



answered Jun 9, 2025 by avibootz
...