Елена обнови решението на 14.03.2014 21:54 (преди почти 11 години)
+def is_pangram(sentence):
+ alphabet = 'абвгдежзийклмнопрстуфхчшщъьюя'
+ for letter in alphabet:
+ if letter not in sentence.lower():
+ return False
+ return True
+
+def char_histogram(text):
+ histogram = {}
+ for letter in text:
+ if letter in histogram:
+ histogram[letter] += 1
+ else:
+ histogram[letter] = 1
+ return histogram
+
+def sort_by(func, arguments):
+ for i in range(0,len(arguments)):
+ for j in range(i, len(arguments)):
+ if func(arguments[i], arguments[j]) > 0:
+ tmp = arguments[i]
+ arguments[i] = arguments[j]
+ arguments[j] = tmp
+ return arguments
+
+def group_by_type(dictionary):
+ grouped = dict()
+ for key, value in dictionary.items():
+ if type(key) in grouped:
+ grouped[type(key)][key] = value
+ else:
+ grouped[type(key)] = dict()
+ grouped[type(key)][key] = value
+ return grouped
+
+def is_anagram(first_word, second_word):
+ word2 = list(second_word)
+ for letter in first_word:
+ if letter not in word2:
+ return False
+ else:
+ word2.remove(letter)
+ return True
+
+def anagrams(words):
+ grouped_by_anagrams = []
+ already_added = []
+ for word1 in words:
+ anagrams_for_word1 = []
+ for word2 in words:
+ if is_anagram(word1, word2) and word2 not in already_added:
+ anagrams_for_word1.append(word2)
+ already_added.append(word2)
+ if anagrams_for_word1 != []:
+ grouped_by_anagrams.append(anagrams_for_word1)
+ return grouped_by_anagrams
- Какво значат
word1
иword2
? - Прочети пак условието на
anagrams
и ще видиш, че ние искаме еднакви букви, а не символи. Има коментари по темата и във форумите - Помисли дали сортирането ти няма да даде грешен резултат в някои случаи