python里大整数相乘相关技巧指南


Posted in Python onSeptember 12, 2014

问题

大整数相乘

思路说明

对于大整数计算,一般都要用某种方法转化,否则会溢出。但是python无此担忧了。

Python支持“无限精度”的整数,一般情况下不用考虑整数溢出的问题,而且Python Int类型与任意精度的Long整数类可以无缝转换,超过Int 范围的情况都将转换成Long类型。

例如:

>>> 2899887676637907866*1788778992788348277389943

5187258157415700236034169791337062588991638L

注意:前面的“无限精度”是有引号的。事实上也是有限制的,对于32位的机器,其上限是:2^32-1。真的足够大了。

为什么Python能够做到呢?请有兴趣刨根问底的去看Python的有关源码。本文不赘述。

在其它语言中,通常用“分治法”解决大整数相乘问题。

但是,这里提供一个非常有意思的计算两个整数相乘的方法,算是做为大整数相乘的演示。

两个整数相乘:阿拉伯乘法。关于这个乘法的详细描述,请看:http://ualr.edu/lasmoller/medievalmult.html

解决(Python)

#!/usr/bin/env python
#coding:utf-8

#阿拉伯乘法
def arabic_multiplication(num1,num2):
  num_lst1 = [int(i) for i in str(num1)] #将int类型的123,转化为list类型的[1,2,3],每个元素都是int类型
  num_lst2 = [int(i) for i in str(num2)]

  #两个list中整数两两相乘
  int_martix = [[i*j for i in num_lst1] for j in num_lst2]

  #将上述元素为数字的list转化为元素类型是str,主要是将9-->'09'
  str_martix = [map(convert_to_str,int_martix[i]) for i in range(len(int_martix))]

  #将上述各个list中的两位数字分开:['01','29','03']-->[0,2,0],[1,9,3]
  martix = [[int(str_martix[i][j][z]) for j in range(len(str_martix[i]))] for i in range(len(str_martix)) for z in range(2)]

  #计算阿拉伯乘法表的左侧开始各项和
  sum_left = summ_left(martix)

  #计算阿拉伯乘法表的底部开始各项和
  sum_end = summ_end(martix)

  #将上述两个结果合并后翻转
  sum_left.extend(sum_end)
  sum_left.reverse()

  #取得各个和的个位的数字(如果进位则加上)
  result = take_digit(sum_left)

  #翻转结果并合并为一个结果字符串数值
  result.reverse()
  int_result = "".join(result)
  print "%d*%d="%(num1,num2)
  print int_result

#将int类型转化为str类型,9-->'09'

def convert_to_str(num):
  if num<10:
    return "0"+str(num)
  else:
    return str(num)

#计算阿拉伯乘法表格左侧开始的各项之和

def summ_left(lst):
  summ = []
  x = [i for i in range(len(lst))]
  y = [j for j in range(len(lst[0]))]
  sx = [i for i in x if i%2==0]
  for i in sx:
    s=0
    j=0
    while i>=0 and j<=y[-1]:
      s = s+ lst[i][j]
      if i%2==1:
        j = j+1
      else:
        j = j
      i = i-1
    summ.append(s)
  return summ

#计算阿拉伯乘法表格底部开始的各项之和

def summ_end(lst):
  summ=[]
  y = [j for j in range(len(lst[0]))]
  ex = len(lst)-1
  for m in range(len(y)):
    s = 0
    i=ex
    j=m
    while i>=0 and j<=y[-1]:
      s= s+lst[i][j]
      if i%2==1:
        j = j+1
      else:
        j=j
      i = i-1
    summ.append(s)

  return summ

#得到各个元素的个位数,如果是大于10则向下一个进位

def take_digit(lst):
  tmp = 0
  digit_list = []
  for m in range(len(lst)):
    lstm = 0
    lstm = lst[m]+tmp
    if lstm<10:
      tmp = 0
      digit_list.append(str(lstm))
    else:
      tmp = lstm/10
      mm = lstm-tmp*10
      digit_list.append(str(mm))
  return digit_list

if __name__=="__main__":
  arabic_multiplication(469,37)
Python 相关文章推荐
Python基于动态规划算法解决01背包问题实例
Dec 06 Python
Python使用progressbar模块实现的显示进度条功能
May 31 Python
windows7 32、64位下python爬虫框架scrapy环境的搭建方法
Nov 29 Python
python实现flappy bird小游戏
Dec 24 Python
Python3多线程基础知识点
Feb 19 Python
postman传递当前时间戳实例详解
Sep 14 Python
利用python实现AR教程
Nov 20 Python
Python 内置函数globals()和locals()对比详解
Dec 23 Python
selenium WebDriverWait类等待机制的实现
Mar 18 Python
Python如何将函数值赋给变量
Apr 28 Python
解决Keras 中加入lambda层无法正常载入模型问题
Jun 16 Python
Python面向对象之内置函数相关知识总结
Jun 24 Python
python里对list中的整数求平均并排序
Sep 12 #Python
python里将list中元素依次向前移动一位
Sep 12 #Python
python time模块用法实例详解
Sep 11 #Python
python+mysql实现简单的web程序
Sep 11 #Python
一个超级简单的python web程序
Sep 11 #Python
python的Template使用指南
Sep 11 #Python
Python基础之函数用法实例详解
Sep 10 #Python
You might like
基于php设计模式中单例模式的应用分析
2013/05/15 PHP
php自动识别文字编码并转换为目标编码的方法
2015/08/08 PHP
Yii调试查看执行SQL语句的方法
2016/07/15 PHP
thinkphp多表查询两表有重复相同字段的完美解决方法
2016/09/22 PHP
php中preg_replace正则替换用法分析【一次替换多个值】
2017/01/17 PHP
php大小写转换函数(strtolower、strtoupper)用法介绍
2017/11/17 PHP
javascript下判断一个对象是否具有指定名称的属性的的代码
2010/01/11 Javascript
用jQuery打造TabPanel效果代码
2010/05/22 Javascript
JavaScript flash复制库类 Zero Clipboard
2011/01/17 Javascript
当某个文本框成为焦点时即清除文本框内容
2014/04/28 Javascript
jQuery获得子元素个数的方法
2015/04/14 Javascript
AngularJS使用ngOption实现下拉列表的实例代码
2016/01/23 Javascript
Jquery ui datepicker设置日期范围,如只能隔3天【实现代码】
2016/05/04 Javascript
深入理解javascript中的 “this”
2017/01/17 Javascript
使用AngularJS2中的指令实现按钮的切换效果
2017/03/27 Javascript
JavaScript实现设置默认日期范围为最近40天的方法分析
2017/07/12 Javascript
webpack配置sass模块的加载的方法
2017/07/30 Javascript
详解wow.js中各种特效对应的类名
2017/09/13 Javascript
swiper动态改变滑动内容的实现方法
2018/01/17 Javascript
使用Node搭建reactSSR服务端渲染架构
2018/08/30 Javascript
Layui点击图片弹框预览的实现方法
2019/09/16 Javascript
[01:20]PWL S2开团时刻第三期——团战可以输 蝙蝠必须死
2020/11/26 DOTA
在Python中操作列表之List.pop()方法的使用
2015/05/21 Python
python 实现红包随机生成算法的简单实例
2017/01/04 Python
Python编程求解二叉树中和为某一值的路径代码示例
2018/01/04 Python
详解如何在python中读写和存储matlab的数据文件(*.mat)
2018/02/24 Python
解决Pycharm 中遇到Unresolved reference 'sklearn'的问题
2020/07/13 Python
8种常用的Python工具
2020/08/05 Python
海淘零差价,宝贝全球购: 宝贝格子
2016/08/24 全球购物
女士和男士时尚鞋在线购物:Shoespie
2019/02/28 全球购物
Linux面试经常问的文件系统操作命令
2015/11/05 面试题
2014年教师节寄语
2014/08/11 职场文书
学籍证明模板
2014/11/21 职场文书
上学路上观后感
2015/06/16 职场文书
2015大学党建带团建工作总结
2015/07/23 职场文书
2016中秋晚会开幕词
2016/03/03 职场文书