高精度运算

高精度运算

高精度运算是指在计算机编程中,对超出常规数据类型(如整型、浮点型)所能表示范围的极大或极精确数值进行的各种数学运算。在标准的计算机编程语言中,内置的整数和浮点数类型有其固定的字节数和精度限制,一旦数字过大或精度过高,就会导致溢出或精度丢失的问题

高精度运算通过创建一种自定义数据结构(如数组或动态链表)来存储极大数值的每一位,从而实现对大整数、大浮点数或任意精度数的加、减、乘、除以及其他高级运算。这种数据结构能够模拟人类手算时多位数列的运算规则,使得在理论上能够处理任意长度和精度的数字。

例如,在C++中,处理高精度数值(即任意长度的大整数)时,可以使用动态数组(std::vector<int>std::deque<char>来分别存储每一位数字,然后编写专门的函数来实现高精度数的加法、减法、乘法和除法等运算。

高精度加法

#include <iostream>
#include <vector>
// 定义高精度整数类
class BigInteger {
public:
    std::vector<int> digits;
    BigInteger(const std::string &str) {
        for (char c : str) {
            digits.push_back(c - '0');
        }
        reverse(digits.begin(), digits.end());
    }
    // 加法函数
    BigInteger operator+(const BigInteger &other) const {
        BigInteger result;
        result.digits.resize(std::max(digits.size(), other.digits.size()) + 1, 0);
        int carry = 0;
        for (size_t i = 0; i < digits.size() || i < other.digits.size() || carry; ++i) {
            int sum = carry;
            if (i < digits.size()) sum += digits[i];
            if (i < other.digits.size()) sum += other.digits[i];
            result.digits[i] = sum % 10;
            carry = sum / 10;
        }
        while (!result.digits.empty() && !result.digits.back()) {
            result.digits.pop_back();
        }
        return result;
    }
};
int main() {
    BigInteger a("123456789");
    BigInteger b("987654321");
    BigInteger sum = a + b;
    // 输出结果,这里需要添加反转输出逻辑
    return 0;
}

高精度减法

BigInteger BigInteger::operator-(const BigInteger &other) const {
    BigInteger result;
    size_t maxLen = std::max(digits.size(), other.digits.size());
    result.digits.resize(maxLen, 0);
    bool borrow = false;
    for (size_t i = 0; i < maxLen; ++i) {
        int difference = borrow ? digits[i] - 1 : digits[i];
        if (i < digits.size()) {
            difference -= (i < other.digits.size()) ? other.digits[i] : 0;
        }
        borrow = difference < 0;
        difference = (borrow ? difference + 10 : difference);
        result.digits[i] = difference;
    }
    // 清理前导零
    while (!result.digits.empty() && !result.digits.back()) {
        result.digits.pop_back();
    }
    return result;
}

高精度乘法

BigInteger BigInteger::operator*(const BigInteger &other) const {
    BigInteger result;
    result.digits.resize(digits.size() + other.digits.size(), 0);
    // 模拟竖式乘法,从低位到高位
    for (size_t i = 0; i < digits.size(); ++i) {
        for (size_t j = 0; j < other.digits.size(); ++j) {
            int product = digits[i] * other.digits[j];
            int index = i + j;
            result.digits[index] += product;
            // 进位处理
            while (result.digits[index] >= 10) {
                result.digits[index] %= 10;
                if (index + 1 < result.digits.size()) {
                    result.digits[index + 1]++;
                } else {
                    result.digits.push_back(1);
                }
            }
        }
    }
    // 清理前导零
    while (!result.digits.empty() && !result.digits.back()) {
        result.digits.pop_back();
    }
    return result;
}
// 示例:
BigInteger product = a * b;

高精度除法

// 由于高精度除法较为复杂,这里仅简述思路,实际实现可能需要更复杂的算法,如长除法或更高效的算法如Karatsuba算法等
BigInteger BigInteger::divide(const BigInteger &divisor) const {
    // 先检查除数是否为0,如果是则抛出异常或错误处理
    if (divisor == BigInteger(0)) throw std::invalid_argument("Divide by zero");
    BigInteger quotient, remainder(*this);
    quotient.digits.clear();
    while (remainder >= divisor) {
        int shift = remainder.digits.size() - divisor.digits.size();
        BigInteger trialDivisor(divisor);
        trialDivisor.digits.resize(shift + divisor.digits.size(), 0);
        BigInteger maxDivisible = remainder / trialDivisor;
        // 更新商和余数
        quotient.digits.insert(quotient.digits.begin(), maxDivisible.digits.begin(), maxDivisible.digits.end());
        remainder -= maxDivisible * divisor;
    }

    return quotient;
}
// 示例:
BigInteger quotient = a.divide(b);

除法部分的实现可能是最复杂的,通常涉及到更复杂的迭代或递归算法。同时,在实际工程中,为了提高效率,还可能需要实现快速模幂、快速乘等高效算法。

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

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

相关文章

引流源码短剧搜索前端源码+内附搜索API

引流源码短剧搜索前端源码内附搜索API&#xff0c;全网短剧搜索前端源码分享&#xff0c;文末附API及使用详解 内含7000短剧资源(不支持在线播放&#xff09;&#xff0c;毕竟搞在线播放挺烧钱的[阴险] 源码直接上传虚拟主机或服务器即可使用&#xff0c;无需其他配置&#x…

jvm 马士兵 01 JVM简介,class文件结构

01.JVM是什么 JVM是一个跨平台的标准 JVM只识别class文件&#xff0c;符合JVM规范的class文件都可以被识别 u1 是一个字节 u2是两个字节

使用网络用户命令行工具的/passwordreq:yes

提示:"新建域时&#xff0c;本地administrator帐户将成为域administrator账户。无法新建域&#xff0c;因为本地administrator账户密码不符合要求。 目前&#xff0c;本地administrator账户不需要密码。我们建议您使用网络用户命令行工具的/passwordreq:yes选项获得该账户…

AI图书推荐:ChatGPT在真实商业世界中的应用

《ChatGPT在真实商业世界中的应用》 (Unleashing The Power of ChatGPT: A Real World Business Applications)首先概述了ChatGPT及其在对话式人工智能领域的影响。接着&#xff0c;你将深入了解ChatGPT的技术方面&#xff0c;理解机器学习算法和自然语言处理如何在后台工作。然…

鸿蒙ArkTs开发,仿抖音个人中心header 下拉放大

如果是iOS 或者android 上实现&#xff0c;可以用Scollview 的contentOffset 来实现&#xff0c;然而在鸿蒙ets中该如何实现&#xff1f;废话不多说开始撸代码 第一步、实现一个header // 创建header&#xff0c;准备一张背景图片BuilderHeaderBuilder(){Column() {Row() {Ima…

社交媒体数据恢复:爱聊

爱聊数据恢复方法 在爱聊的使用过程中&#xff0c;如果遇到数据丢失的情况&#xff0c;可以尝试以下几种方法来恢复数据。 1. 硬盘坏道检测与修复 如果问题是由于硬盘坏道导致的&#xff0c;可以按照以下步骤进行操作&#xff1a; 找到需要修复的坏道磁盘&#xff1a;首先&…

js模块化:修改导入模块的内容,会有影响吗?

起因 element-ui的popper组件相关的层级&#xff0c;是使用popup-manager来统一管理的。 之前试图在自己的组件里导入并使用element-ui的popup-manager&#xff0c;但是层级老是和element-ui组件的层级冲突&#xff0c;看了下源码&#xff0c;竟意外发现&#xff0c;使用popu…

基于若依框架搭建网站的开发日志(一):若依框架搭建、启动、部署

RuoYi&#xff08;基于SpringBoot开发的轻量级Java快速开发框架&#xff09; 链接&#xff1a;开源地址 若依是一款开源的基于VueSpringCloud的微服务后台管理系统&#xff08;也有SpringBoot版本&#xff09;&#xff0c;集成了用户管理、权限管理、定时任务、前端表单生成等…

You don’t have permission.

The document “XXX” could not be saved. You don’t have permission. 1.查看修改了iOS系统库导致的, 根据提示, 进入到"XXX"文件中, 然后commandz回退/取消 2. Xcode 调试遇到的报错&#xff08;持续更新&#xff09;

治疗耳鸣患者案例分享第二期

“患者耳鸣20年了&#xff0c;目前耳朵没有堵或者胀的感觉&#xff0c;但是偶尔有点痒&#xff0c;平时会有头晕头胀这种情况&#xff0c;然后头晕是稍微晕炫一下。然后头疼是经常有的&#xff0c;头胀不经常。” 患者耳鸣持续20年&#xff0c;虽然耳朵没有堵或胀的感觉&#x…

书生浦语训练营第三次课笔记:XTuner 微调 LLM:1.8B、多模态、Agent

Finetune 简介 两种Finetune范式&#xff1a;增量预训练微调、指令跟随微调 微调数据集 上述是我们所期待模型回答的内容&#xff0c;在训练时损失的计算也是基于这个。 训练数据集看起来是这样&#xff0c;但是真正喂给模型的&#xff0c;是经过对话模板组装后的 下图中&…

防火墙的基本概念

我们在 TCP/IP协议四层模型与OSI七层模型 的最后说过&#xff0c;在四层模型中每一层都会有对应的风险&#xff0c;而防火墙就是来阻断这些风险的工具。 防火墙的基本功能 防火墙的分类 目前没有权威而明确的分类 按照实现方式&#xff1a; 硬件防火墙软件防火墙 按照部署…

HNU-人工智能-实验1-A*算法

人工智能-实验1 计科210x 甘晴void 一、实验目的 掌握有信息搜索策略的算法思想&#xff1b; 能够编程实现搜索算法&#xff1b; 应用A*搜索算法求解罗马尼亚问题。 二、实验平台 课程实训平台https://www.educoder.net/shixuns/vgmzcukh/challenges 三、实验内容 3.…

高扬程水泵助力森林消防,守护绿色生命线/恒峰智慧科技

随着人类社会的不断发展&#xff0c;森林资源的保护和管理变得越来越重要。然而&#xff0c;森林火灾却时常威胁着这一宝贵资源。为了有效应对森林火灾&#xff0c;提高灭火效率&#xff0c;高扬程水泵在森林消防中发挥了重要作用。本文将重点介绍高扬程水泵在森林消防中的应用…

AI终端设备的自动化分级

摘要&#xff1a; AI智体被定义为感知环境、做出决策和采取行动的人工实体。 受SAE&#xff08;汽车工程师学会&#xff09;自动驾驶6个级别的启发&#xff0c;AI智体也根据效用和强度进行分类&#xff0c;分为以下几个级别&#xff1a; L0——无AI&#xff0c;有工具&#xf…

机器学习中线性回归算法的推导过程

线性回归是机器学习中监督学习中最基础也是最常用的一种算法。 背景&#xff1a;当我们拿到一堆数据。这堆数据里有参数&#xff0c;有标签。我们将这些数据在坐标系中标出。我们会考虑这些数据是否具有线性关系。简单来说 我们是否可以使用一条线或者一个平面去拟合这些数据的…

力扣每日一题111:二叉树的最小深度

题目 简单 给定一个二叉树&#xff0c;找出其最小深度。 最小深度是从根节点到最近叶子节点的最短路径上的节点数量。 说明&#xff1a;叶子节点是指没有子节点的节点。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;2示例 2&#x…

SpringCloud生态体系介绍

Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发&#xff0c;如服务发现注册、配置中心、智能路由、消息总线、负载均衡、断路器、数据监控等&#xff0c;都可以用Spring Boot的开发风格做到一键启动和部署。 必要说…

【面试经典 150 | 图】除法求值

文章目录 写在前面Tag题目来源解题思路方法一&#xff1a;广度优先搜索 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法&#xff0c;两到三天更新一篇文章&#xff0c;欢迎催更…… 专栏内容以分析题目为主&#xff0c;并附带一些对于本题涉及到的数据结构等内容…

2024年第二十六届“华东杯”(B题)大学生数学建模挑战赛|数学建模完整代码+建模过程全解全析

当大家面临着复杂的数学建模问题时&#xff0c;你是否曾经感到茫然无措&#xff1f;作为2022年美国大学生数学建模比赛的O奖得主&#xff0c;我为大家提供了一套优秀的解题思路&#xff0c;让你轻松应对各种难题。 让我们来看看华东杯 (B题&#xff09;&#xff01; 第一个问题…
最新文章