def f339(a:str,b:str)->str:
    m=len(a)-len(b)
    if m>=0:
      b='0'*m+b
      res=''
      for i in range(len(a)):
            res+=str(int(a)+int(b))
      return res
    else:
      return f339(b,a)
a = "99"
b = "111"
print(f339(a,b))				
			
		ArmandXiao 发表于 2020-2-29 20:25
太强大了
我花了好几行用来将2个字符串补齐,应该有更好的方法。				
			
		ouyunfu 发表于 2020-2-29 20:29
34 ms				
			
		冬雪雪冬 发表于 2020-2-29 20:29
我花了好几行用来将2个字符串补齐,应该有更好的方法。
我绝对你这个足够强大了
太厉害了
我必须学习!				
			
		来晚了
def fun339(a,b):
    def add(num1,num2):
      result = ''
      M = len(num1)
      for i in range(0,M):
            result += str(int(num1)+int(num2))
      return result
    a_lenth = len(a)
    b_lenth = len(b)
    if a_lenth>b_lenth:
      return a + add(a[(a_lenth-b_lenth):],b)
    else:
      return b + add(b[(b_lenth-a_lenth):],a)				
			
		TJBEST 发表于 2020-2-29 21:05
来晚了
26 ms				
			
		zltzlt 发表于 2020-2-29 20:23
如果用递归则不能处理过大的数据
def f339(a,b):
    if len(a)>len(b):
      a,b=b,a
    return b[:-len(a)]+''.join()])
				
			
		塔利班 发表于 2020-2-29 21:24
{:10_275:}23 ms				
			
		 本帖最后由 kinkon 于 2020-2-29 21:58 编辑 
没时间,后面再优化
def f339(a, b):
    a, b = a[::-1], b[::-1]
    alen,blen = len(a), len(b)
    if alen < blen:
      M = alen
    else:
      M = blen
    s = '' 
    for i in range(M):
      s += str(int(a) + int(b))
    s += a + b
    return s[::-1]				
			
		kinkon 发表于 2020-2-29 21:39
没时间,后面在优化
输入 a = "99", b = "111" 结果有误				
			
		 本帖最后由 kinkon 于 2020-2-29 23:54 编辑 
这次应该对了吧
def f339(a, b):
    a, b = a[::-1], b[::-1]
    alen,blen = len(a), len(b)
    if alen < blen:
      M = alen
    else:
      M = blen
    s = '' 
    for i in range(M):
      s += str(int(a) + int(b))[::-1]
    s += a + b
    return s[::-1]
字符串不翻转试试会不会快一些
def f339(a, b):
    alen,blen = len(a), len(b)
    if alen < blen:
      M = alen
    else:
      M = blen
    s = '' 
    for i in range(-M, 0):
      s += str(int(a) + int(b))
    s = a[:-M] + b[:-M] + s
    return s
再精简,好像会更快一些
def f339(a, b):
    M = min(len(a), len(b))
    return a[:-M] + b[:-M] + ''.join() + int(b)) for i in range(-M, 0)])
    				
			
		def fun339(a,b):
    return ''.join()+int(i)) for i in list(zip(a.zfill(len(b)),b))]) if len(a)<len(b) else ''.join()+int(i)) for i in list(zip(a,b.zfill(len(a))))])				
			
		冬雪雪冬 发表于 2020-2-29 20:29
我花了好几行用来将2个字符串补齐,应该有更好的方法。
字符串zfill方法,或者假定a的长度大于b f'{b:0>(len(a)}'				
			
		fan1993423 发表于 2020-2-29 22:05
字符串zfill方法,或者假定a的长度大于b f'{b:0>(len(a)}'
是的				
			
		 本帖最后由 jdzzj 于 2020-2-29 22:14 编辑 
def fun339(a,b):
    res=""
    a=list(a)
    b=list(b)
    
    while len(a)!=len(b):
      if len(a)>len(b):
            b.insert(0,"0")
      else:
            a.insert(0, "0")
    for i in range(len(a)):
      res += str(int(a) + int(b))
    return res				
			
		def fun339(a,b):
    return ''.join() if len(a)<len(b) else ''.join()				
			
		def test(a, b):
    figures = max()
    a = tuple(a.zfill(figures))
    b = tuple(b.zfill(figures))
    a_b = tuple(map(lambda x, y: str(int(x) + int(y)), a, b))
    return ''.join(a_b)
zfill眞好用				
			
		wcshds 发表于 2020-2-29 22:21
zfill眞好用
啊,已经有人用了{:10_257:}				
			
		wcshds 发表于 2020-2-29 22:23
啊,已经有人用了
没事,我相信只是思路巧合,这个我一看完题就反应了zfill和f''两种方法				
			
		a=input('a=')
b=input('b=')
if len(a)>len(b):
   a,b=b,a
else:
   pass
f=''
b1=b
for i in range(len(a)):
   c=int(a)+int(b1)
   f+=str(c)
b2=b[:len(b)-len(a)]
d=b2+f
print(d)
   
来了,怎么设置代码模式