Skip to content

Instantly share code, notes, and snippets.

Created June 9, 2016 17:18
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save anonymous/d1da0072b93e1e7ee3817bcf4f110288 to your computer and use it in GitHub Desktop.
Save anonymous/d1da0072b93e1e7ee3817bcf4f110288 to your computer and use it in GitHub Desktop.
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import string
import itertools
CHARS = "ABCDEFGHI"
def n_unmatch(stra, strb):
return sum(ca != cb for ca,cb in zip(stra, strb))
def trans(str_, perm):
#tr = str.maketrans(CHARS, perm)
tr = string.maketrans(CHARS, perm)
return str_.translate(tr)
def perms(str_):
for p in itertools.permutations(str_):
yield "".join(p)
class ConvertibleStrings:
def leastRemovals(self, A, B):
# こういうのは短く書けるけど途中に print とか挟めないから微妙
return min(n_unmatch(trans(A,perm), B) for perm in perms(CHARS))
def leastRemovals(A, B):
return min(n_unmatch(trans(A,perm), B) for perm in perms(CHARS))
def main():
cs = ConvertibleStrings()
print(cs.leastRemovals("DD", "FF"))
print(cs.leastRemovals("AAAA", "ABCD"))
print(cs.leastRemovals("AAIAIA", "BCDBEE"))
print(cs.leastRemovals("ABACDCECDCDAAABBFBEHBDFDDHHD", "GBGCDCECDCHAAIBBFHEBBDFHHHHE"))
print(len(tuple(itertools.permutations(CHARS))))
if __name__ == "__main__": main()
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment