方法是将两个乘数转为两个包含乘数每位数字的list,
因为在计算中两个list中的数据要反复使用,所以定义第三个list来保存乘法的运算结果,然后使用两重循序模拟列竖式计算出乘法运算的结果, 因为乘法运算每次运算时需要向前移动一位表示扩大10倍,所以定义变量pos标记计算时移动的位数, 每次移动一位
from functools import reduce
def multiply(a, b):
a = list(map(lambda x : int(x), a.strip()))
b = list(map(lambda x : int(x), b.strip()))
c = list(map(lambda x : 0, ("0" + str(a) + str(b)).strip()))
index = len(c) - 1;
for i in range(len(a) -