【五十九】【算法分析与设计】高精度加法和高精度减法

高精度加法

高精度加法,也称为大数加法,是一种能够处理超过标准数据类型(如 int 或 long)允许范围的大数字的算法。

高精度数字通常无法使用单一的标准数据类型来存储。一个常见的方法是使用数组或字符串来表示每一位数字。例如,数字 "123456789" 可以被存储为一个数组 [1,2,3,4,5,6,7,8,9]。

1.

迭代可以看作是只有递的递归。没有归的递归,不需要回溯,因此每个节点的信息,存放的是上个节点的信息。

节点信息,定义i表示当前a的下标,定义j表示当前b的下标,定义carry表示当前节点对应的进位,定义sum表示当前节点的累加和。

怎么判断有没有下一个节点,如何进入下一个节点。

我们的目标是填充c字符串,如果c字符串需要填充,那就进入下一个节点。

如何进去下一个节点,i--,j--即可,下一个节点对应a,b下一个位置。

2.

 
static string add(const string& a, const string& b) { // 定义一个静态函数,接受两个字符串a和b,返回一个字符串
    string c; // 用于存储结果的字符串
    int sum = 0; // 当前位的总和(包括上一位的进位)
    int carry = 0; // 进位值
    int i = a.size() - 1; // 指向字符串a的最后一个字符的索引
    int j = b.size() - 1; // 指向字符串b的最后一个字符的索引
    while (i >= 0 || j >= 0 || sum / 10) { // 当任一字符串还有字符未处理,或者最高位有进位时循环
        int numa = i >= 0 ? a[i] - '0' : 0; // 从a中取出一个数字,如果i已经小于0,则取0
        int numb = j >= 0 ? b[j] - '0' : 0; // 从b中取出一个数字,如果j已经小于0,则取0
        carry = sum / 10; // 上一轮的和大于等于10,产生的进位
        sum = numa + numb + carry; // 计算当前总和
        c.push_back(sum % 10 + '0'); // 将当前总和的个位数转为字符后添加到结果字符串中

        i--, j--; // 移动索引到下一位
    }
    reverse(c.begin(), c.end()); // 反转字符串,因为数字是从最低位开始添加的,所以最终结果要反转过来
    return c; // 返回结果字符串
}

高精度减法

高精度减法,或称为大数减法,是计算机科学中用于处理超过标准数据类型限制的大数字相减的方法。

与高精度加法类似,大数通常使用数组或字符串来存储每一位数字。例如,数字 "987654321" 可以存储为数组 [9, 8, 7, 6, 5, 4, 3, 2, 1],每个数组元素代表一位数字。

1.

定义carry表示进位,定义sum表示当前累加和,定义i表示a字符串的下标,定义j表示b字符串的下标。

默认a>=b,如果a<b只需要计算b-a,然后在前面添加负号即可。

节点信息存放的上一个节点的信息。

where用于判断有没有下一个节点,要不要进入下一个节点。

i--,j--控制进入下一个节点。

2.

怎么判断a字符串和b字符串的大小?

自定义一个compare函数用于判断,因为string内置的compare函数只能判断第一个不同的字符的大小,对于字符串长度相同的时候可以判断,但是如果字符串长度不同就不能进行判断。

如果a的长度大于b的长度,那么a一定大于b。

如果a的长度等于b的长度,那么用内置函数进行判断即可。

如果a的长度小于b的长度,a一定小于b。

3.

封装subtract函数,如果a>=b,正常计算a-b,如果a<b,计算b-a的值,然后在前面添加负号。

4.

减法操作计算完需要去掉尾部的'0',否则反转之后会有前导0。

5.

 
static string _subtract(const string& a, const string& b) { // 定义一个静态函数,用于处理a减b的操作(假设a大于b)
    string c; // 结果字符串
    int carry = 0; // 借位
    int sum = 0; // 当前位相减的结果,含借位
    int i = a.size() - 1; // 指向字符串a的最后一个字符的索引
    int j = b.size() - 1; // 指向字符串b的最后一个字符的索引
    while (i >= 0 || j >= 0) { // 当任一字符串还有字符未处理时循环
        carry = sum < 0 ? -1 : 0; // 根据上一位的结果决定是否需要借位
        int numa = i >= 0 ? a[i] - '0' : 0; // 从a中取出一个数字,如果i已经小于0,则取0
        int numb = j >= 0 ? b[j] - '0' : 0; // 从b中取出一个数字,如果j已经小于0,则取0
        sum = carry + numa - numb; // 计算当前位的结果,含借位

        c.push_back(sum < 0 ? sum + 10 + '0' : sum + '0'); // 处理借位,将结果字符添加到结果字符串中
        i--, j--; // 移动索引到下一位
    }
    while (c.size() > 0 && c.back() == '0') c.pop_back(); // 去除结果字符串末尾的所有'0'
    if (c.size() == 0) c.push_back('0'); // 如果结果字符串为空,则添加'0'(结果为0)
    reverse(c.begin(), c.end()); // 反转字符串,因为数字是从最低位开始添加的,所以最终结果要反转过来
    return c; // 返回结果字符串
}
static string subtract(const string& a, const string& b) { // 定义一个静态函数,用于返回两个字符串a和b的相减结果
    if (compare(a, b) == 1) return _subtract(a, b); // 如果a大于b,直接计算a减b
    else return "-" + _subtract(b, a); // 如果b大于或等于a,计算b减a并在结果前加负号
}
static int compare(const string& a, const string& b) { // 定义一个静态函数,用于比较两个字符串的大小
    if (a.size() > b.size()) return 1; // 如果a的长度大于b的长度,返回1(a大于b)
    else if (a.size() == b.size()) return a.compare(b) == -1 ? -1 : 1; // 如果长度相同,使用字符串比较,返回比较结果
    else return -1; // 如果a的长度小于b的长度,返回-1(a小于b)
}

结尾

最后,感谢您阅读我的文章,希望这些内容能够对您有所启发和帮助。如果您有任何问题或想要分享您的观点,请随时在评论区留言。

同时,不要忘记订阅我的博客以获取更多有趣的内容。在未来的文章中,我将继续探讨这个话题的不同方面,为您呈现更多深度和见解。

谢谢您的支持,期待与您在下一篇文章中再次相遇!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/561509.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

算法课程笔记——STL键值对map

map当下标无限的数组 重点是对应关系&#xff0c;一般不修改compare 类比set 没有lowerbound&#xff0c;因为遍历是无序的 ; map不能用sort函数排序 但可用vector转化为map使用 std::set<std::pair<TKEY, mutable TVAL> > ≈ std::map<TKEY, TVAL>

电子印章盖骑缝章

电子印章盖骑缝章是指在电子文档&#xff08;如PDF文件&#xff09;中&#xff0c;使用电子印章技术&#xff0c;为文档添加一个跨越多页、连续显示的电子印章图像&#xff0c;以模拟传统纸质文档上的骑缝章效果。以下是实现电子印章盖骑缝章的步骤&#xff1a; 一. 准备电子印…

C++_特殊类的设计和单例模式

文章目录 学习目标&#xff1a;1.请设计一个类&#xff0c;不能被拷贝2. 请设计一个类&#xff0c;只能在堆上创建对象3. 请设计一个类&#xff0c;只能在栈上创建对象4. 请设计一个类&#xff0c;不能被继承5. 请设计一个类&#xff0c;只能创建一个对象(单例模式) 特殊类的设…

C++修炼之路之多态--多态的条件与例外,重载+重写+重定义

目录 前言 一&#xff1a;构成多态的条件及一些特殊情况&#xff08;前提是构成父子类&#xff09; 1.多态是在不同的继承关系的类对象&#xff0c;去调用同一函数&#xff0c;产生了不同的结果 2.两个条件 3.三同的两个例外 1.协变---返回值类型可以不同&#xff0c;但必…

外贸客户开发软件哪个好用一点,效果好数据精准的?

选择外贸客户开发软件时&#xff0c;你需要考虑软件的功能、易用性、数据质量以及价格等因素。以下是一些常用的外贸客户开发软件&#xff0c;它们都具有不同的特点和优势&#xff1a; 易谷歌地图数据采集大师&#xff1a; 专为做外贸的朋友开发的一款基于谷歌地图数据采集的软…

Python-VBA函数之旅-hash函数

目录 一、hash函数的定义&#xff1a; 二、hash函数的工作方式&#xff1a; ​三、hash函数的优缺点&#xff1a; 四、hash函数的常见应用场景&#xff1a; 1、hash函数&#xff1a; 1-1、Python&#xff1a; 1-2、VBA&#xff1a; 2、推荐阅读&#xff1a; 个人主页&…

C++进阶:搜索树

目录 1. 二叉搜索树1.1 二叉搜索树的结构1.2 二叉搜索树的接口及其优点与不足1.3 二叉搜索树自实现1.3.1 二叉树结点结构1.3.2 查找1.3.3 插入1.3.4 删除1.3.5 中序遍历 2. 二叉树进阶相关练习2.1 根据二叉树创建字符串2.2 二叉树的层序遍历I2.3 二叉树层序遍历II2.4 二叉树最近…

37、Tomato(VulnHub)

Tomato 一、nmap 2211是ssh的端口&#xff0c;21的ftp也不是弱密码 二、web渗透 随便看看 目录爆破 /seclists/Discovery/Web-Content/common.txt /antibot_image/antibots/readme.txt 发现该站点存在反爬机制 /antibot_image/antibots/info.php 提示我们该网页存在个参数 GET&…

Java高阶私房菜:高并发之线程池底层原理学习

以往我们需要获取外部资源&#xff08;数据源、Http请求等&#xff09;时&#xff0c;需要对目标源创建链接对象&#xff0c;三次握手成功后方可正常使用&#xff0c;为避免持续的资源占用和可能的内存泄漏&#xff0c;还需要调用目标对象close方法释放资源销毁对象。这一建一销…

排序算法集合

912. 排序数组 趁着这道题总结下排序方法 1.快速排序 算法描述 1.从数列中挑出一个元素&#xff0c;称为"基准"&#xff08;pivot&#xff09;&#xff0c; 2.重新排序数列&#xff0c;所有比基准值小的元素摆放在基准前面&#xff0c;所有比基准值大的元素摆在基…

稀碎从零算法笔记Day54-LeetCode:39. 组合总和

题型&#xff1a;数组、树、DFS、回溯 链接&#xff1a;39. 组合总和 - 力扣&#xff08;LeetCode&#xff09; 来源&#xff1a;LeetCode 题目描述 给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target &#xff0c;找出 candidates 中可以使数字和为目标数…

智慧化赋能园区新未来:探讨智慧园区如何以科技创新为引擎,推动产业转型升级

随着科技的飞速发展&#xff0c;智慧化已成为推动园区产业升级和转型的重要引擎。智慧园区&#xff0c;以其高效、便捷、智能的特性&#xff0c;正逐步改变传统的产业园区模式&#xff0c;为产业发展注入新的活力。本文旨在探讨智慧园区如何以科技创新为引擎&#xff0c;推动产…

60.网络游戏逆向分析与漏洞攻防-利用数据包构建角色信息-根据数据包内容判断数据包作用

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 如果看不懂、不知道现在做的什么&#xff0c;那就跟着做完看效果 现在的代码都是依据数据包来写的&#xff0c;如果看不懂代码&#xff0c;就说明没看懂数据包…

SAP SD 销售业务中免费货物之免费货物主数据

销售业务中&#xff0c;免费货物在您与客户协商价格时起着重要作用。在零售、化工或消费品这样的行业部门中&#xff0c;通常以免费货物的形式向客户提供折扣。如需了解SAP系统针对销售与分销业务中提供的标准解决方案概览&#xff0c;可先了解本博客博文&#xff1a;SAP销售与…

Visual Studio2010源码编译curl_7_60

一、源码解压目录内容 很开心里面可以找到CMakeLists.txt文件&#xff0c;说明可以实用CMake工具进行构建&#xff0c;由于多数开源项目都选择实用CMake作为构建编译工具&#xff0c;大家蝇该都比较熟练了。 二、实用CMake开始构建Visual Studio 2010工程 很顺利整个构建过程没…

机器学习基本流程

Jupyter Notebook 代码连接&#xff1a; machine_learning_demo machine_learning_ensembles Step 1: Imports and Configuration import pandas as pd import numpy as np import copy import json import pickle import joblib import lightgbm as lgb import optuna impor…

vscode设置conda默认python环境,简单有效

本地conda 可能安装了各种环境&#xff0c;默认的vscode总是base环境&#xff0c;这时你想要在vscode调试python代码&#xff0c;使用默认的环境没有安装对应的包就会遇到报错解决这个问题的方法很简单ctrlshiftp 调出命令面板 再输入 select interpreter , 选择 python 选择解…

【Pytorch】PytorchCPU版或GPU报错异常处理(10X~4090D)

Pytorch为CPU版或GPU使用报错异常处理 文章目录 Pytorch为CPU版或GPU使用报错异常处理0.检查阶段1. 在conda虚拟环境中安装了torch2.卸载cpuonly3.从tsinghua清华源安装不完善误为cpu版本4.用tsinghua清华源安装成cpu错误版本5.conda中torch/vision/cudatoolkit版本与本机cuda版…

安装第三方包报错 import pcapy ... ImportError: DLL load failed: 找到不到指定的模块——解决办法

1、问题描述 安装pcapy时&#xff0c;安装正常&#xff0c;但引用失败。具体过程如下&#xff1a;下载pcapy&#xff0c;下载地址&#xff1a;pcapy PyPI ​下载WinPcap开发工具包&#xff0c;下载地址&#xff1a;WinPcap 的 开发人员资源 ​安装pcapy&#xff0c;进入\pcap…

达梦数据库的DMRMAN工具-管理备份(备份集校验)

达梦数据库的DMRMAN工具-管理备份&#xff08;备份集校验&#xff09; DMRMAN 中使用 CHECK 命令对备份集进行校验&#xff0c;校验备份集是否存在及合法。 语法如下&#xff1a; CHECK BACKUPSET <备份集目录> [DEVICE TYPE <介质类型> [PARMS <介质参数>…