首页 > 其他分享 >高精度乘法的实现

高精度乘法的实现

时间:2024-06-22 20:58:57浏览次数:16  
标签:乘低 高精度 实现 存入 答案 乘数 精度 乘法

         这是C++算法基础-基础算法专栏的第九篇文章,专栏详情请见此处


引入

        上次我们学习了高精度加法的实现,这次我们要学习高精度减法的实现。

        高精度乘法与高精度加法的定义、前置过程都是大致相同的,如果想了解具体内容,可以移步至我的这篇博客:高精度加法计算的实现

        在这里就不再详细讲解,只讲解主体过程qwq

        这里需要说明,此博客(包括后面一篇),都是实现两个高精度数之间的计算,而算法基础课中仅仅实现了一个高精度数​​​​​​​和一个低精度数​​​​​​​之间的计算,思路和代码上两者有所不同。

主体过程

        呃,高精度乘高精度先等会儿,我们先看一种简单的情况。

        高精度乘低精度

        高精度乘低精度的原理和小学学习的竖式乘法是一样的。

        

         概括来说,从个位开始,将低精度乘数与高精度乘数的每一位相乘,存进积的对应位置上,若当前位达到10进位,也就是将下一位加上当前位(整)除以10,并把当前位模10

        89\times 123用高精度计算(123为高精度乘数,89为低精度乘数),先乘个位,3\times 89267,发现267大于等于10,所以将267(整)除以10,得26,将其存入答案的十位,再将26710,得7,将其存入答案的个位;

        再乘十位,2\times 89+26204,发现204大于等于10,所以将204(整)除以10,得20,将其存入答案的百位,再将20410,得4,将其存入答案的十位;

        再乘百位,1\times 89+20109,发现109大于等于10,所以将109(整)除以10,得10,将其存入答案的千位,再将10910,得9,将其存入答案的百位;

        最后,千位的10大于等于10,所以将10(整)除以10,得1,将其存入答案的万位,再将1010,得0,将其存入答案的千位;得到答案10947

        高精度乘高精度

        我们通过高精度乘低精度可以看出,运算89\times 123,实际就是将123分解成1\times 10^{2}+2\times 10^{1}+3\times 10^{0},再分别用每一位去乘89

        高精度乘高精度也是一样的。若还想计算高精度乘高精度的89 \times 123,我们就可以受高精度乘低精度的启发,将89123分解成8 \times 10^{1}+9\times 10^{0}1\times 10^{2}+2\times 10^{1}+3\times 10^{0},再分别相乘,即9\times 10^{0}\times 3\times 10^{0}+8 \times 10^{1}\times 3\times 10^{0}+9\times 10^{0}\times 2\times 10^{1}+8 \times 10^{1}\times 2\times 10^{1}+9\times 10^{0}\times 1\times 10^{2}+8 \times 10^{1}\times 1\times 10^{2},化简,得9\times 3\times 10^{0}+8 \times 3\times 10^{1}+9\times 2\times 10^{1}+8 \times 2\times 10^{2}+9\times 1\times 10^{2}+8 \times 1\times 10^{3}

        从这个复杂的式子上可以看出,若当前两个乘数分别的位置ij相乘时,答案会存储在i+j这个位置上。

        嗯,有点复杂,结合代码食用会好一些。

代码

        下面给出高精度乘法的代码:

void mul(int a[],int b[],int c[]){
	clear(c);
	for(int i=0;i<L-1;i++){
		for(int j=0;j<=i;j++)
			c[i]+=a[j]*b[i-j];
		if(c[i]>=10){
			c[i+1]+=c[i]/10;
			c[i]%=10;
		}
	}
}

上一篇-高精度减法的实现    C++算法基础专栏文章    下一篇-高精度除法的实现


每周六更新一篇文章,内容一般是自己总结的经验或是在其他网站上整理的优质内容

点个赞,关注一下呗~

标签:乘低,高精度,实现,存入,答案,乘数,精度,乘法
From: https://blog.csdn.net/wyuchen123/article/details/137878319

相关文章

  • Gitlab服务器邮箱配置,实现自动为用户发送邮件(注册发送验证链接)
    一.配置前准备工作及说明服务器系统版本:CentOS7postfix,并在终端运行systemctlstatuspostfix检查服务是否已在运行状态,如果显示activate则表示正在运行[root@sage~]$systemctlstatuspostfix●postfix.service-PostfixMailTransportAgentLoaded:loaded(/......
  • 面试官:请你实现三栏布局并且优先加载中间内容 我:稳啦- ̗̀(๑ᵔ⌔ᵔ๑)
    前言三栏布局是网页设计中一种经典布局方式,它将页面分为三个垂直部分:左栏、中栏和右栏,三栏在同一行显示。这种布局模式在很多网站的首页或内容密集型页面中非常常见,因为它能够有效地组织信息,提供良好的用户体验。常常也是作为面试常考题出现,今天将为大家介绍常见的三栏布......
  • Java 面试题:如何保证集合是线程安全的? ConcurrentHashMap 如何实现高效地线程安全?
    在多线程编程中,保证集合的线程安全是一个常见而又重要的问题。线程安全意味着多个线程可以同时访问集合而不会导致数据不一致或程序崩溃。在Java中,确保集合线程安全的方法有多种,包括使用同步包装类、锁机制以及并发集合类。最简单的方法是使用Collections.synchronized......
  • 【后台管理系统】Vuex实现简单组件间通信
    Vuex是组件间通信的一种方式,可以实现任意组件间的通信。官方文档:开始|Vuex(vuejs.org)https://vuex.vuejs.org/zh/guide/Vuex应用的核心其实就是一个共享的仓库store,在store.state中储存你需要修改的状态,在mutation中储存修改状态的方法,再使用commit提交修改方法。如果需......
  • 粘包问题、socketserver模块实现并发
    TCP协议------------黏包现象11.服务端连续执行三次recv22.客户端连续执行三次send3问题:服务端一次性接收到了客户端三次的消息该现象称为"黏包现象"4--------------------------------------5黏包现象产生的原因:61.收消息的时候,不知道每次接收的数据到......
  • 深入PHP框架开发:实现高效的日志记录系统
    在软件工程中,日志记录是一种记录程序运行时发生事件的实践,它对于调试、监控和安全分析至关重要。PHP框架提供了多种方式来实现日志记录,这些方式可以帮助开发者捕获和存储关键信息。本文将详细探讨在PHP框架中实现日志记录的不同策略和技术。日志记录的基本概念在深入探讨......
  • 如何用GO语言实现快速排序算法?
    本章教程,介绍一下如何用GO语言实现基础排序算法中的快速排序。快速排序(Quicksort)是一种高效的排序算法,它采用分治法策略,将一个数组分成两个子数组,然后递归地对这两个子数组进行排序。一、程序代码packagemainimport( "fmt" "math/rand" "time")//quickSo......
  • 使用三种方式通过数组实现拷贝复制
    三种通过数组的方式进行数组的拷贝,其本质都是通过地址传参,来实现数组的拷贝。1、通过数组访问这种访问数组的方式是最常见的voidcopy1(doubletarget[],doublesource[],intlen){for(inti=0;i<len;++i){target[i]=source[i];}}i......
  • 前端页面实现【矩阵表格与列表】
    实现页面: 1.动态表绘制(可用于矩阵构建)<template><div><h4><b>基于层次分析法的权重计算</b></h4><tabletable-layout="fixed"><thead><tr><thv-for="(_,colIndex)in(numRows......
  • C#使用MJpeg实现视频流发送与显示
    1、发送视频流:usingSystem;usingSystem.Collections.Concurrent;usingSystem.Collections.Generic;usingSystem.Drawing;usingSystem.Globalization;usingSystem.IO;usingSystem.Linq;usingSystem.Net.Sockets;usingSystem.Text;usingSystem.Threading.Tasks......