Ангел обнови решението на 19.03.2014 15:42 (преди почти 11 години)
+ALPHABET_CYR = 'явертъуиопасдфгхйклзьцжбнмюч'
+ALPHABET_LAT = 'qwertyuiopasdfghjklzxcvbnm'
+
+
+def is_pangram(sentence):
+ return set(ALPHABET_CYR).issubset(set(sentence.lower()))
+
+
+def char_histogram(text):
+ histogram = {}
+ for char in text:
+ if char in histogram:
+ histogram[char] += 1
+ else:
+ histogram[char] = 1
+ return histogram
+
+
+def sort_by(func, arguments):
+ if len(arguments) <= 1:
+ return arguments
+ pivot = arguments.pop(0)
+ left = []
+ right = []
+ center = [pivot]
+ while arguments:
+ current_argument = arguments.pop(0)
+ coef = func(pivot, current_argument)
+ if coef > 0:
+ left.append(current_argument)
+ elif coef < 0:
+ right.append(current_argument)
+ else:
+ center.append(current_argument)
+ return sort_by(func, left) + center + sort_by(func, right)
+
+
+def group_by_type(dictionary):
+ groups = {}
+ for key, value in dictionary.items():
+ if type(key) in groups:
+ groups[type(key)][key] = value
+ else:
+ groups[type(key)] = {key: value}
+ return groups
+
+
+def word_letter_set(word):
+ return set(word).intersection(set(ALPHABET_CYR).union(set(ALPHABET_LAT)))
+
+
+def anagrams(words):
+ classes = []
+ while words:
+ base_word = words.pop()
+ cur_class = [word for word in words
+ if word_letter_set(word) == word_letter_set(base_word)]
+ words = [word for word in words if word not in cur_class]
+ cur_class.append(base_word)
+ classes.append(cur_class)
+ return classes