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编写脚本使IE实现代理上网的教程
Apr 23 Python
python实现将元祖转换成数组的方法
May 04 Python
在Django的视图中使用数据库查询的方法
Jul 16 Python
Python使用三种方法实现PCA算法
Dec 12 Python
Python学生成绩管理系统简洁版
Apr 05 Python
Flask之flask-session的具体使用
Jul 26 Python
python 判断参数为Nonetype类型或空的实例
Oct 30 Python
PyCharm的设置方法和第一个Python程序的建立
Jan 16 Python
Python学习笔记之字符串和字符串方法实例详解
Aug 22 Python
python3.7将代码打包成exe程序并添加图标的方法
Oct 11 Python
使用tensorflow显示pb模型的所有网络结点方式
Jan 23 Python
keras实现多GPU或指定GPU的使用介绍
Jun 17 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
VML绘图板②脚本--VMLgraph.js、XMLtool.js
2006/10/09 PHP
php和javascript之间变量的传递实现代码
2012/12/19 PHP
php设计模式之单例、多例设计模式的应用分析
2013/06/30 PHP
jQuery 1.5最新版本的改进细节分析
2011/01/19 Javascript
textarea 控制输入字符字节数(示例代码)
2013/12/27 Javascript
jQuery获取iframe的document对象的方法
2014/10/10 Javascript
jQuery中index()方法用法实例
2014/12/27 Javascript
jQuery前端分页示例分享
2015/02/10 Javascript
JavaScript实现的伸展收缩型菜单代码
2015/10/14 Javascript
JS实现的几个常用算法
2016/11/12 Javascript
JavaScript触发onScroll事件的函数节流详解
2016/12/14 Javascript
用jQuery实现可输入多选下拉组合框实例代码
2017/01/18 Javascript
jquery平滑滚动到顶部插件使用详解
2017/05/08 jQuery
Angular实现搜索框及价格上下限功能
2018/01/19 Javascript
Angular学习笔记之集成三方UI框架、控件的示例
2018/03/23 Javascript
详解ES6中的三种异步解决方案
2018/06/28 Javascript
JavaScript设计模式之代理模式实例分析
2019/01/16 Javascript
微信小程序云开发如何实现数据库自动备份实现
2019/08/16 Javascript
Vue开发中遇到的跨域问题及解决方法
2020/02/11 Javascript
JS前端广告拦截实现原理解析
2020/02/17 Javascript
[07:03]显微镜下的DOTA2第九期——430圣堂刺客杀戮秀
2014/06/20 DOTA
Python 处理数据的实例详解
2017/08/10 Python
利用Python yagmail三行代码实现发送邮件
2018/05/11 Python
对python中的float除法和整除法的实例详解
2019/07/20 Python
Python大数据之从网页上爬取数据的方法详解
2019/11/16 Python
python 实现Flask中返回图片流给前端展示
2020/01/09 Python
PyCharm永久激活方式(推荐)
2020/09/22 Python
Keras官方中文文档:性能评估Metrices详解
2020/06/15 Python
希尔顿酒店官方网站:Hilton Hotels
2017/06/01 全球购物
求职信内容考虑哪几点
2013/10/05 职场文书
会议邀请函范文
2014/01/09 职场文书
北京奥运会口号
2014/06/21 职场文书
篮球社团活动总结
2014/06/27 职场文书
golang中实现给gif、png、jpeg图片添加文字水印
2021/04/26 Golang
vue+element ui实现锚点定位
2021/06/29 Vue.js
python单向链表实例详解
2022/05/25 Python