本文整理匯總了Python中bag.Bag.subtract方法的典型用法代碼示例。如果您正苦於以下問題:Python Bag.subtract方法的具體用法?Python Bag.subtract怎麽用?Python Bag.subtract使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類bag.Bag
的用法示例。
在下文中一共展示了Bag.subtract方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: Bag
# 需要導入模塊: from bag import Bag [as 別名]
# 或者: from bag.Bag import subtract [as 別名]
dict_hash_table = dict.snarf_dictionary(options.dict_fn)
the_phrase = Bag(args[0])
print("Pruning dictionary. Before: {} bags ...".format(len(dict_hash_table.keys())),
file=sys.stderr, end='')
# Now convert the hash table to a list, longest entries first. (This
# isn't necessary, but it makes the more interesting anagrams appear
# first.)
# While we're at it, prune the list, too. That _is_ necessary for the
# program to finish before you grow old and die.
the_dict_list = [[k, dict_hash_table[k]]
for k in dict_hash_table.keys()
if the_phrase.subtract(k)]
# Note that sorting entries "alphabetically" only makes partial sense,
# since each entry is(at least potentially) more than one word(all
# the words in an entry are anagrams of each other).
def biggest_first_then_alphabetically(a, b):
a = a[1][0]
b = b[1][0]
result = cmp(len(b), len(a))
if not result:
result = cmp(a, b)
return result
the_dict_list.sort(biggest_first_then_alphabetically)
print(" After: {} bags.".format(len(the_dict_list)),
示例2: Bag
# 需要導入模塊: from bag import Bag [as 別名]
# 或者: from bag.Bag import subtract [as 別名]
args = parser.parse_args()
dict_hash_table = dict.snarf_dictionary_from_file(args.dictionary)
the_phrase = Bag("".join(args.words))
print("Pruning dictionary. Before: {} bags ...".format(len(dict_hash_table.keys())), file=sys.stderr, end="")
# Now convert the hash table to a list, longest entries first. (This
# isn't necessary, but it makes the more interesting anagrams appear
# first.)
# While we're at it, prune the list, too. That _is_ necessary for the
# program to finish before you grow old and die.
the_dict_list = sorted([[k, dict_hash_table[k]] for k in dict_hash_table.keys() if the_phrase.subtract(k)], key=len)
print(" After: {} bags.".format(len(the_dict_list)), file=sys.stderr)
pr = cProfile.Profile()
pr.enable()
result = anagrams(the_phrase, the_dict_list)
pr.disable()
ps = pstats.Stats(pr, stream=sys.stderr).sort_stats("cumulative")
ps.print_stats()
print("{} anagrams of {}".format(len(result), " ".join(args.words)), file=sys.stderr)
for a in result:
sys.stdout.write("(")
for i, w in enumerate(a):