#!/usr/bin/python2 # -*- coding: utf-8 -*- # † import string from math import log # 基数変換. 10進数の{num}を{base}進数にします。 def int2base(num, base, digits=string.digits+string.ascii_uppercase): assert base > 1 is_negative = num < 0 num = abs(num) if num == 0: return digits[0] s = '' while num != 0: s = digits[num % base] + s num /= base if is_negative: s = '-' + s return s # 基数変換. {base}進数で表現された{s}を10進数にします。 #base2int = lambda s, base: int(s, base) def base2int(s, base, digits=string.digits+string.ascii_uppercase): if len(s) == 0: return 0 is_negative = s[0] == '-' if is_negative: s = s[1:] num = 0 for c in s: num *= base num += digits.index(c) if is_negative: num *= -1 return num # s <= t か def leq(s, t): n1 = len(s) n2 = len(t) if n1 < n2: return True if n1 > n2: return False for i in xrange(n1): if ord(s[i]) > ord(t[i]): return False return True # i文字の開始位置 def create(B, i): if i == 1: return '10' res = int2base(i-1, B) + str(B-2) * (i-2) + str(B-1) + '0' return res def f(B, D): DB = base2int(D, B) lo, hi = 0, len(D) while hi - lo > 1: md = (lo + hi) / 2 if leq(create(B, md), D): lo = md else: hi = md x = base2int(create(B, lo), B) z, r = divmod(DB-x, hi) w = z + B**lo m = int(log(w, B)) + 1 # p = int2base(w, B) # return p[r] return (w / B**(m-1-r)) % B B = int(raw_input()) D = raw_input() res = f(B, D) print res