Мария обнови решението на 17.03.2014 00:05 (преди почти 11 години)
+from functools import cmp_to_key
+
+
+def is_pangram(sentence):
+ sentence = sentence.lower()
+ alphabet = "абвгдежзийклмнопрстуфхцчшщъьюя"
+ for letter in alphabet:
+ if sentence.count(letter) == 0:
+ return False
+ return True
+
+
+def char_histogram(text):
+ result = {}
+ for letter in text:
+ result[letter] = text.count(letter)
+ return result
+
+
+def sort_by(func, arguments):
+ return sorted(arguments, key=cmp_to_key(func))
+
+
+def group_by_type(dictionary):
+ result = {}
+ for key in dictionary:
+ if not type(key) in result:
+ result[type(key)] = {key: dictionary[key]}
+ else:
+ result[type(key)][key] = dictionary[key]
+ return result
+
+
+def remove_white_spaces_and_dashes(sorted_word):
+ for i in range(0, sorted_word.count(" ")):
+ sorted_word.remove(" ")
+ for i in range(0, sorted_word.count("-")):
+ sorted_word.remove("-")
+ return sorted_word
+
+
+def anagrams_of_word(word, text):
+ result = []
+ for w in text:
+ if (remove_white_spaces_and_dashes(sorted(word.lower())) ==
+ remove_white_spaces_and_dashes(sorted(w.lower()))):
+ result.append(w)
+ return result
+
+
+def not_in(word, list_of_lists):
+ for list in list_of_lists:
+ if word in list:
+ return False
+ return True
+
+
+def anagrams(words):
+ result = []
+ for word in words:
+ if not_in(word, result):
+ result.append(anagrams_of_word(word, words))
+ return result
-
list_of_lists
е много неподходящо име, казахме ви, че не искаме да се съдържа типа в името - азбуката може да се изнесе като константа извън функцията
- забележи, че
anagrams
не се интересува от символите, а само от буквите