Skip to content

Instantly share code, notes, and snippets.

@hlian
Created July 24, 2010 17:58
Show Gist options
  • Select an option

  • Save hlian/488860 to your computer and use it in GitHub Desktop.

Select an option

Save hlian/488860 to your computer and use it in GitHub Desktop.
Google Code Jam: Practice Mode: Alien Numbers
#!/usr/bin/env python
"""
Google Code Jam: Practice Mode: Alien Numbers.
http://code.google.com/codejam/contest/dashboard?c=32003
"""
import os
import sys
def to_int(alien, src):
n = len(src)
alphabet = dict(zip(src, range(n)))
for i, char in enumerate(reversed(alien)):
yield alphabet[char] * (n ** i)
def from_int(m, dst):
n = len(dst)
while m > 0:
m, leftover = m / n, m % n
yield dst[leftover]
def convert(alien, src, dst):
return ''.join(reversed(list(from_int(sum(to_int(alien, src)), dst))))
def main(handle):
for i, line in enumerate(handle.readlines()[1:]):
print('Case #%d: %s' % (i + 1, convert(*line.split())))
if __name__ == '__main__':
main(sys.stdin)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment