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解析xml文件实例分享
Dec 04 Python
python实现端口转发器的方法
Mar 13 Python
Python实现telnet服务器的方法
Jul 10 Python
Python如何快速实现分布式任务
Jul 06 Python
Python使用MD5加密算法对字符串进行加密操作示例
Mar 30 Python
Sanic框架路由用法实例分析
Jul 16 Python
举例讲解Python常用模块
Mar 08 Python
python实现爬虫抓取小说功能示例【抓取金庸小说】
Aug 09 Python
python return逻辑判断表达式实现解析
Dec 02 Python
TensorFlow中如何确定张量的形状实例
Jun 23 Python
利用python如何实现猫捉老鼠小游戏
Dec 04 Python
Python实现疫情地图可视化
Feb 05 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
星际初学者游戏中永远要做的事
2020/03/04 星际争霸
PHP中for循环与foreach的区别
2017/03/06 PHP
javascript Math.random()随机数函数
2009/11/04 Javascript
基于jquery的监控数据是否发生改变
2011/04/11 Javascript
父节点获取子节点的字符串示例代码
2014/02/26 Javascript
基于jquery实现轮播焦点图插件
2016/03/31 Javascript
移动端横屏的JS代码(beta)
2016/05/16 Javascript
微信小程序 loading(加载中提示框)实例
2016/10/28 Javascript
Angular ui.bootstrap.pagination分页
2017/01/20 Javascript
使用jQuery实现购物车结算功能
2017/08/15 jQuery
JS实现合并json对象的方法
2017/10/10 Javascript
JavaScript中字符串的常用操作方法及特殊字符
2018/03/18 Javascript
react native基于FlatList下拉刷新上拉加载实现代码示例
2018/09/30 Javascript
解决jquery validate 验证不通过后验证正确的信息仍残留在label上的方法
2019/08/27 jQuery
JavaScript 禁止用户保存图片的实现代码
2020/04/28 Javascript
js异步接口并发数量控制的方法示例
2020/11/22 Javascript
Vue使用鼠标在Canvas上绘制矩形
2020/12/24 Vue.js
[00:37]2016完美“圣”典风云人物:rOtk宣传片
2016/12/09 DOTA
[01:00] DOTA2英雄背景故事第五期之重力引力法则谜团
2020/07/16 DOTA
Python的几个高级语法概念浅析(lambda表达式闭包装饰器)
2016/05/28 Python
pytorch + visdom 处理简单分类问题的示例
2018/06/04 Python
快速解决pandas.read_csv()乱码的问题
2018/06/15 Python
python使用epoll实现服务端的方法
2018/10/16 Python
PyQt5 实现给窗口设置背景图片的方法
2019/06/13 Python
解决Python3.8用pip安装turtle-0.0.2出现错误问题
2020/02/11 Python
Python3.7安装PyQt5 运行配置Pycharm的详细教程
2020/10/15 Python
改变生活的男士内衣:SAXX Underwear
2019/08/28 全球购物
自主招生自荐信范文
2013/12/04 职场文书
优秀毕业生自荐信范文
2014/01/01 职场文书
宠物店的创业计划书范文
2014/01/11 职场文书
厨房领班竞聘演讲稿
2014/04/23 职场文书
市场推广策划方案
2014/06/02 职场文书
会计人员演讲稿
2014/09/11 职场文书
教师群众路线教育实践活动个人对照检查材料
2014/11/04 职场文书
写给导师的自荐信
2015/03/06 职场文书
CSS实现切角+边框+投影+内容背景色渐变效果
2021/11/01 HTML / CSS