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获取脚本所在目录的正确方法
Apr 15 Python
改进Django中的表单的简单方法
Jul 17 Python
浅析Python的web.py框架中url的设定方法
Jul 11 Python
Python基于time模块求程序运行时间的方法
Sep 18 Python
python中判断文件编码的chardet(实例讲解)
Dec 21 Python
Win7 64位下python3.6.5安装配置图文教程
Oct 27 Python
用python标准库difflib比较两份文件的异同详解
Nov 16 Python
Python3.6中Twisted模块安装的问题与解决
Apr 15 Python
详解有关PyCharm安装库失败的问题的解决方法
Feb 02 Python
详解Python 实现 ZeroMQ 的三种基本工作模式
Mar 24 Python
.img/.hdr格式转.nii格式的操作
Jul 01 Python
使用python爬取抖音app视频的实例代码
Dec 01 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 header Content-Type类型小结
2011/07/03 PHP
php curl_init函数用法
2014/01/31 PHP
PHP下的Oracle客户端扩展(OCI8)安装教程
2014/09/10 PHP
PHP多线程模拟实现秒杀抢单
2018/02/07 PHP
一个基于jquery的文本框记数器
2012/09/19 Javascript
javascript scrollTop正解使用方法
2013/11/14 Javascript
JS闭包、作用域链、垃圾回收、内存泄露相关知识小结
2016/05/16 Javascript
Canvas实现放射线动画效果
2017/02/15 Javascript
JS基于正则表达式的替换操作(replace)用法示例
2017/04/28 Javascript
浅谈如何使用 webpack 优化资源
2017/10/20 Javascript
vuex 解决报错this.$store.commit is not a function的方法
2018/12/17 Javascript
实例讲解vue源码架构
2019/01/24 Javascript
Vue自定义属性实例分析
2019/02/23 Javascript
微信小程序中使用echarts的实现方法
2019/04/24 Javascript
JavaScript定时器使用方法详解
2020/03/26 Javascript
Python 2.7中文显示与处理方法
2018/07/16 Python
pytorch 调整某一维度数据顺序的方法
2018/12/08 Python
Python threading.local代码实例及原理解析
2020/03/16 Python
Python3.7.0 Shell添加清屏快捷键的实现示例
2020/03/23 Python
Win10环境中如何实现python2和python3并存
2020/07/20 Python
Numpy中np.max的用法及np.maximum区别
2020/11/27 Python
使用django自带的user做外键的方法
2020/11/30 Python
Python 中如何使用 virtualenv 管理虚拟环境
2021/01/21 Python
css3实现波纹特效、H5实现动态波浪效果
2018/01/31 HTML / CSS
拥有超过850家商店的美国在线派对商店:Party City
2018/10/21 全球购物
Footshop罗马尼亚:最好的运动鞋选择
2019/09/10 全球购物
中学门卫岗位职责
2013/12/26 职场文书
档案接收函
2014/01/13 职场文书
广告词串烧
2014/03/19 职场文书
高三毕业寄语
2014/04/10 职场文书
结婚保证书(卖身契)
2015/02/26 职场文书
义卖募捐活动总结
2015/05/09 职场文书
简短清晨问候语
2015/11/10 职场文书
关于 Python json中load和loads区别
2021/11/07 Python
日元符号 ¥
2022/02/17 杂记
详解Nginx的超时keeplive_timeout配置步骤
2022/05/25 Servers