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 13 Python
Python下Fabric的简单部署方法
Jul 14 Python
python僵尸进程产生的原因
Jul 21 Python
Python中的错误和异常处理简单操作示例【try-except用法】
Jul 25 Python
Python聊天室程序(基础版)
Apr 01 Python
Mac下Anaconda的安装和使用教程
Nov 29 Python
Python3按一定数据位数格式处理bin文件的方法
Jan 24 Python
python下载库的步骤方法
Oct 12 Python
Numpy 理解ndarray对象的示例代码
Apr 03 Python
Python检测端口IP字符串是否合法
Jun 05 Python
详解Flask前后端分离项目案例
Jul 24 Python
Django项目如何正确配置日志(logging)
Apr 29 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实现WEB动态网页静态
2006/10/09 PHP
PHP 程序员的调试技术小结
2009/11/15 PHP
解析php中用PHPMailer来发送邮件的示例(126.com的例子)
2013/06/24 PHP
分享一段php获取linux服务器状态的代码
2014/05/27 PHP
ThinkPHP权限认证Auth实例详解
2014/07/22 PHP
PHP管理依赖(dependency)关系工具 Composer的自动加载(autoload)
2014/08/18 PHP
thinkphp实现like模糊查询实例
2014/10/29 PHP
php微信开发之关注事件
2018/06/14 PHP
深入理解javascript中defer的作用
2013/12/11 Javascript
详解Angular的数据显示优化处理
2016/12/26 Javascript
Vue实现星级评价效果实例详解
2019/12/30 Javascript
JavaScript实现随机点名器
2020/03/25 Javascript
python base64 decode incorrect padding错误解决方法
2015/01/08 Python
使用Python实现一个简单的项目监控
2015/03/31 Python
Python实现数据库编程方法详解
2015/06/09 Python
python创建列表并给列表赋初始值的方法
2015/07/28 Python
python使用super()出现错误解决办法
2017/08/14 Python
浅谈Matplotlib简介和pyplot的简单使用——文本标注和箭头
2018/01/09 Python
在Python中使用gRPC的方法示例
2018/08/08 Python
Python提取特定时间段内数据的方法实例
2019/04/01 Python
python 使用装饰器并记录log的示例代码
2019/07/12 Python
Python math库 ln(x)运算的实现及原理
2019/07/17 Python
Pandas操作CSV文件的读写实现方法
2019/11/13 Python
Python 如何定义匿名或内联函数
2020/08/01 Python
pycharm2020.2 配置使用的方法详解
2020/09/16 Python
记一次python 爬虫爬取深圳租房信息的过程及遇到的问题
2020/11/24 Python
pycharm中leetcode插件使用图文详解
2020/12/07 Python
html5中localStorage本地存储的简单使用
2017/06/16 HTML / CSS
HTML5 Canvas实现360度全景图的示例代码
2018/01/29 HTML / CSS
网络工程师专家职业发展路线
2014/02/14 职场文书
四查四看剖析材料
2014/02/14 职场文书
活动总结报告格式
2014/05/09 职场文书
小学生节约用水倡议书
2014/05/15 职场文书
房展策划方案
2014/06/07 职场文书
网聊搭讪开场白
2015/05/28 职场文书
纯CSS实现hover图片pop-out弹出效果的实例代码
2021/04/16 HTML / CSS