ACWING 高精度-加减乘除 791 - 794

news2024/10/6 8:27:14

读取字符串的高精度数字,然后用int数组存上,通过最基础的每位加减乘除和进位等操作完成。

下方给出了所有的操作函数,注意函数的所有输入均为vector 的数组,并且数组存储是从数的低位开始存1000 = [0,0,0,1],和正常存储相反,这是为了便于操作。

791. 高精度加法

题目

791. 高精度加法 - AcWing题库

给定两个正整数,计算它们的和。

输入格式

共两行,每行包含一个整数。

输出格式

共一行,包含所求的和。

数据范围

1 ≤ 整数长度 ≤ 100000

样例输入1

12
23

样例输出1

35

思路

将输入数据按位存储到数组A[] B[], 然后从低位开始遍历相加,大于10进位

// O(n)
// C = A + B, A >= 0, B >= 0
// A B C 数组是从数的低位开始存1000 = [0,0,0,1]
vector<int> add(const vector<int> &A, const vector<int> &B)
{
	if(A.size() < B.size()) return add(B, A); // 保证A数组长
	vector<int> C;
	int carry = 0; // 进位
	int i;
	for(i = 0; i < B.size(); i++)
	{
		carray = A[i] + B[i] + carray;
		C.push_back(carray % 10);
		carray /= 10;
	}
	for(i; i < A.size(); i++)
	{
		carray = A[i] + carray;
		C.push_back(carray % 10);
		carray /= 10;
	}
	if(carray) C.push_back(carray);
	return C;
}

AcWing 792 高精度减法

题目

792. 高精度减法 - AcWing题库

给定两个正整数(不含前导 00),计算它们的差,计算结果可能为负数。

输入格式

共两行,每行包含一个整数。

输出格式

共一行,包含所求的差。

数据范围

1≤整数长度≤105

输入样例:

32
11

输出样例:

21

思路

输入输出方式与高精度加法一样,区别在于减法当前位的结果应该+10之后再%10,判断当前结果如果小于0,应该将当前临时变量变为1,下次计算时减去之前借的1。 注意结尾要去除前导0.

注意控制输入 sub的是A >= 0, B >= 0,A B C 数组是从数的低位开始存1000 = [0,0,0,1],A > B, 注意一定是大减小。

为了实现大减小,可以用cmp函数。

// O(n)
// C = A + B, A >= 0, B >= 0
// A B C 数组是从数的低位开始存1000 = [0,0,0,1]
// A > B, 注意一定是大减小
vector<int> sub(const vector<int> &A, const vector<int> &B)
{
    vector<int> C;
    int carry = 0;
    for(int i = 0; i < A.size(); ++i)
    {
        carry = A[i] - carry;
        if(i < B.size()) carry -= B[i];
        C.push_back((carry + 10) % 10);
        // carry<0 表示从上一位借了一位
        if(carry < 0) carry = 1;
        else carry = 0;
    }
    while (C.size() > 1 && C.back() == 0) C.pop_back();
    return C;
}

// 保证sub是大减小,判断谁打
// A >= 0, B >= 0
// A B 数组是从数的低位开始存1000 = [0,0,0,1]
bool cmp(const vector<int> &A, const vector<int> &B)
{
    if(A.size() != B.size()) return A.size() > B.size();
    for(int i = A.size(); i ; i++) // 从高位开始比较
        if(A[i] != B[i]) return A[i] > B[i];
    return true;
}

AcWing 793 高精度乘法

793. 高精度乘法 - AcWing题库

题目

给定两个非负整数(不含前导 0) A 和 B,请你计算 A×B 的值。

输入格式

共两行,第一行包含整数 A,第二行包含整数 B。

输出格式

共一行,包含 A×B 的值。

数据范围

1≤A的长度≤100000,
0≤B的长度≤10000

输入样例:

2
3

输出样例:

6

思路

  • 高精度乘低精度
    将高精度数组的每一位数乘以低精度数后进位,最终得到的进位再一直向高精度数组延伸填充。注意去除前导零。
// O(nm)
// C = A * B, A >= 0, B >= 0
// A 数组是从数的低位开始存1000 = [0,0,0,1]
// 高精度乘低精度
vector<int> mul(const vector<int> &A, const int b) {
    vector<int> C;
    int carry = 0;
    for (int i = 0; i < A.size() || carry; i++) {
        if (i < A.size()) carry += A[i] * b;
        C.push_back(carry % 10);
        carry /= 10;
    }
    while (C.size() > 1 && C.back() == 0) C.pop_back();
    return C;
}
  • 高精度乘高精度 43. 字符串相乘

二层循环乘累加起来,注意递进结果起始位置。在来一个循环遍历结果数组进位。注意去除前导零。

// O(nm)
// C = A * B, A >= 0, B >= 0
// A B 数组是从数的低位开始存1000 = [0,0,0,1]
// 高精度乘高精度
vector<int> mul2(const vector<int> &A, const vector<int> &B) {
    vector<int> C(A.size() + B.size());
    for(int i = 0; i < A.size(); i++)
    {
        for(int j = 0; j < B.size(); i++)
        {
            C[i + j] += A[i] * B[i];
        }
    }
    int carry = 0;
    for(int i = 0; i < C.size(); i++){
        carry = C[i];
        C[i] = carry % 10;
        carry /= 10;
    }
    while (C.size() > 1 && C.back() == 0) C.pop_back();
    return C;
}

AcWing 794 高精度除法

Acwing 794 高精度除法

题目

给定两个非负整数(不含前导 0) A,B,请你计算 A/B 的商和余数。

输入格式

共两行,第一行包含整数 A,第二行包含整数 B。

输出格式

共两行,第一行输出所求的商,第二行输出所求余数。

数据范围

1≤A的长度≤100000,
1≤A的长度≤10000,
B 一定不为 0

输入样例:

7
2

输出样例:

3

思路

  • 高精度除以低精度

从被除数A的高位开始,即A.size() - 1尝试除以b得到每一个商位置的值,循环,将上一次除以的余数结果*10 + 当前A[i]存的被除数 得到此位置的被除数,一直循环除到结束。其实这个过程就是竖式的除法原理。

在这里插入图片描述

// O(n)
// A / b = C ... r, A >= 0, b > 0
// A C 数组是从数的低位开始存1000 = [0,0,0,1]
pair<vector<int>, int> div(const vector<int> &A, int b)
{
    vector<int> C;
    int r = 0; // 余数
    for(int i = A.size() - 1; i; --i)
    {
        r = 10 * r + A[i]; // 向低一位移动除法
        C.push_back(r / b); // 存的时候从高位开始存
        r %= b; // 这一部分除完之后得到的余数,下一次移动后继续除法
    }
    reverse(C.begin(), C.end()); // 翻转为从低位开始存
    while (C.size() > 1 && C.back() == 0) C.pop_back(); // 去除前导零
    return {C, r};
}
  • 高精度除以高精度

对于两个高精度数,类似高精度除以低精度,还是从A的高位开始尝试除以整个B,这时候A的高位类似上面 r = 10 * r + A[i]; 截取出来一部分很麻烦,可以直接用整个A,让B来对齐,即B向高位移动x位即可,这时候A/B一定只有B的高位非0值的正在除。然后循环移动的x位直到0位,如下图即可计算出。

其中A/B的试除通过循环减直到A < B的时候即可,减成功的次数就是该位的商。循环到最后余下的数即余数

在这里插入图片描述

// O((n-m)*n)
// A / B = C ... R, A >= 0, b > 0
// A B C数组是从数的低位开始存1000 = [0,0,0,1]
pair<vector<int>, vector<int>> div2(vector<int> A, const vector<int> &B) {
    vector<int> C, R; // 商 余数
    int c_size = A.size() - B.size(); // 商的长度
    c_size = c_size > 1 ? c_size : 1; // 防止A比B小短,结果数组最小长度为1
    C.resize(c_size, 0);
    
    // 枚举补0的个数,即将B低位补零使得和每次被除数A的高位对齐
    // eg2: 11111 / 11 --> 11111 / 11000 --> 0111 / 110 --> 01 / 11
    for(int i = c_size; i >= 0; --i)
    {
        vector<int> Bp(i, 0); // 前面补i个0
        for(int x : B) Bp.push_back(x); // Bp后面是B

        // 当A >= Bp 时候就一直通过减来得到除的结果
        int c = 0;
        while(cmp(A, Bp))
        {
            c++;
            A = sub(A, Bp);
        }
        C.push_back(c);
    }
    while (C.size() > 1 && C.back() == 0) C.pop_back(); // 去除前导零
    R = A;
    return {C, R};
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux -- 进阶 Web服务器 虚拟主机 -- 基于端口号

虚拟主机 一个Web 服务器&#xff0c;如果只能运行一个网站的话&#xff0c;那么对于一些经费不是很足的小公司来说&#xff0c; 那就有些奢侈了&#xff0c;资源没有办法完全利用上 &#xff08; 无论是 内存&#xff0c;CPU&#xff0c;硬盘&#xff0c;带宽等等 &#xff09…

EIScopus检索 | 2023年智能交通与未来出行国际会议(CSTFM 2023)

会议简介 Brief Introduction 2023年智能交通与未来出行国际会议(CSTFM 2023) 会议时间&#xff1a;2023年7月28日-30日 召开地点&#xff1a;中国长沙 大会官网&#xff1a; CSTFM 2023-2023 International Conference on Smart Transportation and Future Mobility(CSTFM 202…

OpenCL编程指南-3.3矢量数据类型

矢量数据类型 OpenCL C还增加了对矢量数据类型的支持。矢量数据类型如下定义&#xff0c;首先是类型名&#xff0c;具体包括char、uchar、short、ushort、int、uint、float、long或ulong&#xff0c;后面是一个字面值n来定义矢量中的元素个数。对于所有矢量数据类型&#xff0…

母亲节快到了,祝所有母亲节日快乐!Happy Mother‘s Day

《游子吟》唐孟郊 慈母手中线&#xff0c;游子身上衣。 临行密密缝&#xff0c;意恐迟迟归。 谁言寸草心&#xff0c;报得三春晖。 My kind mother has a needle and thread in her hand,Making new clothes for her son who is to travel far away. She is busy sewing c…

FE_Vue学习笔记 Vue监视数据的原理

1 通过更新时的一个问题-this.personList[0] { 更新值 } 不起作用 引入 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title><script type"text/javascript" src"…

每日一博 - 闲聊“突发流量”的应对之道

文章目录 概述思路 概述 面对“突发流量”的情况,我会采取以下应急措施: 扩容现有资源。这是最直接和最常用的方法。可以通过增加CPU、内存、节点等来扩容。典型案例是双11等大促期间,阿里会大规模扩容幕布等系统以应对流量激增。横向扩展,增加更多服务器或节点。通过增加服务…

lambda处理异常四种方式

最近对接第三方呼叫系统&#xff0c;第三方SDK的所有方法里都有异常抛出&#xff0c;因为用到了lambda&#xff0c;所以异常处理还是很必要的。 本文主要用到了四种解决方案&#xff1a; 直接代码块处理自定义函数式接口&#xff0c;warp静态方法通过Either 类型包装通过Pair 类…

目前收集到好用且免费的ChatGPT镜像站

ChatGPT是一个基于人工智能的聊天机器人&#xff0c;它可以与用户进行自然语言交互。ChatGPT使用了最新的自然语言处理技术&#xff0c;包括深度学习和神经网络&#xff0c;以便更好地理解用户的意图和回答用户的问题。 ChatGPT可以回答各种问题&#xff0c;包括但不限于常见问…

Linux——进程信号2

阻塞信号 信号其他相关常见概念 实际执行信号的处理动作称为信号递达(Delivery) 信号从产生到递达之间的状态,称为信号未决(Pending)。 进程可以选择阻塞 (Block )某个信号。 被阻塞的信号产生时将保持在未决状态,直到进程解除对此信号的阻塞,才执行递达的动作. 注意,阻塞和忽略…

一文4000字用Jmeter +Maven+jenkins实现接口性能全自动化测试

背景&#xff1a; 首先用jmeter录制或者书写性能测试的脚本&#xff0c;用maven添加相关依赖&#xff0c;把性能测试的代码提交到github&#xff0c;在jenkins配置git下载性能测试的代码&#xff0c;配置运行脚本和测试报告&#xff0c;配置运行失败自动发邮件通知&#xff0c…

分布式id解决方法--雪花算法

uuid&#xff0c;jdk自带&#xff0c;但是数据库性能差&#xff0c;32位呀。 mysql数据库主键越短越好&#xff0c;Btree产生节点分裂&#xff0c;大大降低数据库性能&#xff0c;所以uuid不建议。 redis的自增&#xff0c;但是要配置维护redis集群&#xff0c;就为了一个id&a…

【前后端分离博客】学习笔记01 --- 登录模块Sa-Token

前言 用于记录自己学习博客项目的流程 基于Springboot Vue3 开发的前后端分离博客 项目源码&#xff1a;Blog: 基于SpringBoot Vue3 TypeScript Vite的个人博客&#xff0c;MySQL数据库&#xff0c;Redis缓存&#xff0c;ElasticSearch全文搜索&#xff0c;支持QQ、Gite…

20230509MTCNN2

卷积切分图片 怎么切分图片? 使用opencv,PIL切分图片有什么问题? 慢 使用 卷积来切分图片 卷积的运算过程 类似于切图 卷积 对输入图片的尺寸 有没有 的要求? 就是 输入的图片尺寸 必须大于 卷积核的大小 test1.py import torch from torch import nn""&quo…

springboot + vue3实现视频播放Demo

文章目录 学习链接前言ffmpeg安装ffmpeg配置环境变量分割视频文件 后台配置WebConfig 前端代码video.js示例安装依赖视频播放组件效果 Vue3-video-play示例安装依赖main.js中使用视频播放组件效果 学习链接 ffmpeg官网 长时长视频java存储及vue播放解决方法 【 攻城略地 】vue…

BitKeep逆势崛起:千万用户的信任,终点还未到来

在全球范围内&#xff0c;BitKeep钱包如今已拥有超过千万忠实用户。 当我得知这一令人震撼的数字时&#xff0c;既感到惊讶&#xff0c;同时也觉得这是意料之中的事情。几年来关注BitKeep的发展历程&#xff0c;我深切地感受到了这家公司的蓬勃壮大。回顾2018年他们发布的第一个…

linux0.12-8-9-fork.c

[362页] 1、 verify_area函数给其他文件使用的&#xff0c;跳转开始位置&#xff1b; 2、 copy_mem函数复制内存页表&#xff1b; 3、 copy_process函数是fork.c主要函数&#xff1b; 4、find_empty_process函数就2个作用&#xff1a;在一个范围内找last_pid和找空槽&#xff1…

如何利用互联网优势进行茶叶销售?

茶叶是中国传统文化的重要组成部分&#xff0c;具有丰富的文化内涵和高度的营养价值。如今&#xff0c;随着互联网的普及&#xff0c;越来越多的茶叶销售商&#xff08;文章编辑ycy6221&#xff09;开始利用互联网的优势来开拓市场。本文将介绍如何利用互联网优势进行茶叶销售。…

SecureCRT的下载安装

亲测成功了&#xff0c;按照下面的步骤完成即可&#xff01; 下载安工具包包地址连接&#xff1a;网盘地址点击即可 提取码&#xff1a;0lp7 1、下载SecureCRT 2、从百度网盘下载SecureCRT&#xff0c;页面如下 3、安装SecureCRT 4、激活SecureCRT 第一步&#xff1a;打开安装…

自学Java怎么找工作?好程序员学员大厂面试经验分享!

简历要详细&#xff1a; 简历中的项目用到的技术点和个人负责的模块尽量写详细一些。其次&#xff0c;根据自己项目中用到的熟悉的技术点&#xff0c;在个人技能介绍模块去突出&#xff0c;面试官基本会根据你简历上写的去提问的&#xff0c;这样我们回答起来就会更加得心应手。…

【多线程初阶四】单例模式阻塞队列

目录 &#x1f31f;一、单例模式 &#x1f308;1、饿汉模式 &#x1f308;2、懒汉模式&#xff08;重点&#xff01;&#xff09; &#x1f31f;二、工厂模式 &#x1f31f;三、阻塞式队列 &#x1f308;1、阻塞队列是什么&#xff1f; &#x1f308;2、…