【马蹄集】第二十四周——高精度计算专题

高精度计算专题



目录

  • MT2191 整数大小比较
  • MT2192 A+B problem
  • MT2193 A-B problem
  • MT2194 大斐列
  • MT2195 升级版斐波那契数列
  • MT2196 2的N次幂




MT2191 整数大小比较

难度:黄金    时间限制:1秒    占用内存:128M
题目描述

给出两个正整数,判断它们的大小。

格式

输入格式:两个正整数。
输出格式:若前者大,输出 >;若后者大,输出 <;若一样大,输出 =

样例 1

输入:1412894619244619891 23762842222

输出:>

备注

保证所有数在 2 100 2^{100} 2100 以内。


相关知识点:高精度计算


题解


虽然这道题是比较数字的大小,但实际上我们不用关心其数字的取值范围(可以从字符串对象的角度出发进行比较)。对于任意两个正整数,它们之间的大小关系可根据以下两步进行比较:

  1. 数字长度。对于正整数而言,显然长度越长的数更大。
  2. 若长度相等,则从数的最高位到最低位依次比较大小,在某位上具有更大数字的数更大。

若 1、2 之后未能找到更大的数,则说明这两个数的取值相同。

基于此,可直接写出求解该题的完整代码(已 AC):

/*MT2191 整数大小比较 
*/
#include<bits/stdc++.h> 
using namespace std;// 比较两个大数的大小 
int compare(string stra, string strb)
{// 根据长度判断大小关系 int lenA = stra.length();int lenB = strb.length();if(lenA > lenB) return 1;if(lenA < lenB) return -1;// 长度相等需要进一步判断for(int i=0; i<lenA; i++){if(stra[i] - strb[i] > 0) return 1;if(stra[i] - strb[i] < 0) return -1;}// 或者直接比较字符串大小// if(stra > strb) return 1;// else if(stra < strb) return -1;// else return return 0;
}// 打印结果
void printResult(int result)
{if(result > 0) cout<<">"<<endl;else if(result < 0) cout<<"<"<<endl;else cout<<"="<<endl;
}int main( )
{// 获取输入 string stra, strb;cin>>stra>>strb;// 比较两个大数的大小int result = compare(stra, strb);// 输出比较结果printResult(result);return 0;
} 



MT2192 A+B problem

难度:黄金    时间限制:1秒    占用内存:128M
题目描述

计算 A + B ( 1 ≤ A , B ≤ 10 10000 ) A+B(1\le A,B\le{10}^{10000}) A+B(1A,B1010000)

格式

输入格式:两行每行一个整数 A , B A,B A,B
输出格式:一个整数 A + B A+B A+B

样例 1

输入:

1
1

输出:

2


相关知识点: 高精度计算


题解


这道题考察的是大数运算(加法)。关于如何实现大数加法运算的分析请见博客 【算法与数据结构】——大数运算 。下面给出多位数加法的执行流程:

在这里插入图片描述

多位数加法的过程涉及到对各个位的加法运算,因此在处理大数的加法运算时,通常会用一个 int 型数组来存储大数在各个位上的值。例如,数:122333444455555666666,可通过一个足够长的数组 a r y [ ] ary[\ ] ary[ ] ,使 a r y [ 0 ] = 1 , a r y [ 1 ] = 2 , a r y [ 3 ] = 2 , … , a r y [ 20 ] = 6 ary\left[0\right]=1,ary\left[1\right]=2,ary\left[3\right]=2,\ldots,ary\left[20\right]=6 ary[0]=1,ary[1]=2,ary[3]=2,,ary[20]=6 进行存储。采取数位与索引大小相对应的存储方式(即数的低位对应较小的索引,高位对应较大的索引),是为了便于大数在执行加法运算时的进位可直接在数组中向后拓展。接下来,就能按照以上思路扫描数组并对各个位进行加法运算。最后,单独用一层循环处理进位即可。

下面直接给出求解本题的完整代码(已 AC):

/*MT2192 A+B problem 
*/
#include<bits/stdc++.h> 
using namespace std;const int N = 1e4+5;
int numa[N], numb[N];// 计算两个大数之和(输入为字符串) 
void getSum(string stra, string strb)
{// 赋初值memset(numa, 0, sizeof(numa));memset(numb, 0, sizeof(numb));int tmp = 0;// 将两个字符串保存至 int 型数组中(注意逆序) for(int i=stra.length()-1; i>=0; i--)numa[tmp++] = stra[i] - '0';tmp = 0;for(int i=strb.length()-1; i>=0; i--)numb[tmp++] = strb[i] - '0';// 将数组中的每个数按位进行加法运算for(int i=0;i<N;i++)numa[i] += numb[i];// 对存放加法结果的数组执行进位处理for(int i=0; i<N; i++){numa[i+1] += numa[i] / 10;numa[i] %= 10;}
}// 输出大数加法后的结果 
void printBigData()
{// 从最高位向后扫描,直到第 1 个非 0 数字出现 int p = N-1;while(numa[p] == 0) p--;while(p >= 0) cout<<numa[p--];cout<<"\n";
} int main( )
{// 获取输入 string stra, strb;cin>>stra>>strb;// 对两个大数进行加法运算 getSum(stra, strb);// 输出和printBigData();return 0;
} 


MT2193 A-B problem

难度:黄金    时间限制:1秒    占用内存:128M
题目描述

计算 A − B ( 1 ≤ B ≤ A ≤ 10 10000 ) A-B(1\le B\le A\le{10}^{10000}) AB(1BA1010000)

格式

输入格式:两行每行一个整数 A , B A,B A,B
输出格式:一个整数 A − B A-B AB

样例 1

输入:

2
1

输出:

1

相关知识点: 高精度计算


题解


这道题考察的是大数运算(减法)。关于如何实现大数减法运算的分析请见博客 【算法与数据结构】——大数运算 。下面给出多位数减法的执行流程:

在这里插入图片描述

多位数减法需要用到 int 型数组来存储大数在各个位上的值,其存储规则和大数加法一致(即低位对应较小的索引,高位对应较大的索引)。接下来,只需要扫描数组,在每个位上按照以上思路进行减法运算即可得到大数减法的结果。

下面直接给出求解本题的完整代码(已 AC):

/*MT2193 A-B problem 
*/
#include<bits/stdc++.h> 
using namespace std;const int N = 1e4+5;
int numa[N], numb[N];// 计算两个大数之差(输入为字符串) 
void getSub(string stra, string strb)
{// 赋初值memset(numa, 0, sizeof(numa));memset(numb, 0, sizeof(numb));int tmp = 0;// 将两个字符串保存至 int 型数组中(注意逆序) for(int i=stra.length()-1; i>=0; i--)numa[tmp++] = stra[i] - '0';tmp = 0;for(int i=strb.length()-1; i>=0; i--)numb[tmp++] = strb[i] - '0';// 将数组中的每个数按位进行减法运算for(int i=0;i<N;i++){numa[i] -= numb[i];if(numa[i] < 0){// 借位 numa[i+1]--; numa[i] += 10;}}
}// 输出大数减法后的结果 
void printBigData()
{// 从最高位向后扫描,直到第 1 个非 0 数字出现 int p = N-1;while(numa[p] == 0) p--;while(p > -1) cout<<numa[p--];cout<<"\n";
} int main( )
{// 获取输入 string stra, strb;cin>>stra>>strb;// 对两个大数进行减法运算 getSub(stra, strb);// 输出和printBigData();return 0;
} 


MT2194 大斐列

难度:黄金    时间限制:1秒    占用内存:128M
题目描述

计算斐波那契数列第 n n n 项。
斐波那契数列定义为: F [ 1 ] = 1 , F [ 2 ] = 1 F[1] = 1,F[2] = 1 F[1]=1F[2]=1,递推关系为: F [ N ] = F [ N − 1 ] + F [ N − 2 ] F[N] = F[N-1] + F[N-2] F[N]=F[N1]+F[N2]。即: 1 、 1 、 2 、 3 、 5 、 8 、 13 、 21 、 34 、 … … 1、1、2、3、5、8、13、21、34、…… 112358132134……

格式

输入格式:一个整数 n n n
输出格式:一个整数 F [ n ] F[n] F[n]

样例 1

输入:6

输出:8

备注

对于 30% 的数据: 3 ≤ n ≤ 20 3≤n≤20 3n20
对于 100% 的数据: 3 ≤ n ≤ 5000 3≤n≤5000 3n5000


相关知识点:高精度计算


题解


这道题实际上就是求斐波那契数列:即通过迭代公式 F [ N ] = F [ N − 1 ] + F [ N − 2 ] F[N] = F[N-1] + F[N-2] F[N]=F[N1]+F[N2],不断获取下一个值。但是斐波那契数列的增长速度非常快,通过编写 Python 代码可知(代码如下),斐波那契数列的第 5000 个数的长度达到了 1045。因此这道题是一道妥妥的大数加法问题。

# 求斐波那契的第 5000 项
ary = [1,1]
for i in range(2,5000):ary.append(ary[i-1]+ary[i-2])
print(ary[4999])
print(len(str(ary[4999])))

Python 求解斐波那契数列

所以这里依然需要用到大数加法。具体的实现方式和前面类似,在此就不赘述。

下面给出基于以上思路写出的完整代码(已 AC):

/*MT2194 大斐列 通过 python 算出最后数字(即第 5000 项)的长度为 1045
*/
#include<bits/stdc++.h> 
using namespace std;const int N = 1100;
int numa[N], numb[N], numc[N];// 计算斐波那契数列
void getFibonacci(int n)
{// 赋初值memset(numa, 0, sizeof(numa));memset(numb, 0, sizeof(numb));memset(numc, 0, sizeof(numc));numa[0] = numb[0] = 1;n -= 2;// 递推求解斐波那契数列并统计前缀和 while(n--){// 将数组中的每个数按位进行加法运算 for(int i=0;i<N;i++)numc[i] = numa[i] + numb[i];// 对存放加法结果的数组执行进位处理for(int i=0; i<N; i++){numc[i+1] += numc[i] / 10;numc[i] %= 10;}// 将数组进行前向赋值(从而实现递推)memcpy(numa, numb, sizeof(numb));memcpy(numb, numc, sizeof(numc));}
}// 输出大数加法后的结果 
void printBigData()
{// 从最高位向后扫描,直到第 1 个非 0 数字出现 int p = N-1;while(numc[p] == 0) p--;while(p > -1) cout<<numc[p--];cout<<"\n";
} int main( )
{// 获取输入 int n;cin>>n;// 求出斐波那契数列 getFibonacci(n);// 输出指定项 printBigData();return 0;
} 


MT2195 升级版斐波那契数列

难度:黄金    时间限制:1秒    占用内存:128M
题目描述

我们都知道斐波那契数列一项是前两项的和,现在我们规定一个升级版斐波那契数列,其一项为前三项的和,要求算其前 n n n 项的和。即,定义: F [ 1 ] = 1 , F [ 2 ] = 1 , F [ 3 ] = 1 F[1] = 1,F[2] = 1,F[3] = 1 F[1]=1F[2]=1F[3]=1,递推关系为: F [ N ] = F [ N − 1 ] + F [ N − 2 ] + F [ N − 3 ] F[N] = F[N-1] + F[N-2] + F[N-3] F[N]=F[N1]+F[N2]+F[N3]

格式

输入格式:一个整数 n n n
输出格式:前 n n n 项的和。

样例 1

输入:4

输出:6

备注

其中: 4 ≤ n ≤ 1000 4\le n \le 1000 4n1000


相关知识点:高精度计算


题解


这道题依然考察了大数加法,和前面一题类似,下面直接给出求解本题的完整代码(已 AC):

/*MT2195 升级版斐波那契数列 通过 python 算出最后数字(即第 1000 项)的长度为 265,整个数列的数字之和长度为 265
*/
#include<bits/stdc++.h> 
using namespace std;const int N = 300;
int numa[N], numb[N], numc[N], numd[N], preSum[N];// 计算斐波那契数列
void getFibonacci(int n)
{// 赋初值memset(numa, 0, sizeof(numa));memset(numb, 0, sizeof(numb));memset(numc, 0, sizeof(numc));memset(numd, 0, sizeof(numd));memset(preSum, 0, sizeof(preSum));numa[0] = numb[0] = numc[0] = 1;preSum[0]  = 3;n -= 3;// 递推求解斐波那契数列并统计前缀和 while(n--){// 将数组中的每个数按位进行加法运算 for(int i=0;i<N;i++)numd[i] = numa[i] + numb[i] + numc[i];// 对存放加法结果的数组执行进位处理for(int i=0; i<N; i++){numd[i+1] += numd[i] / 10;numd[i] %= 10;}// 将当前项累加至前缀和数组中for(int i=0;i<N;i++)preSum[i] += numd[i];for(int i=0; i<N; i++){preSum[i+1] += preSum[i] / 10;preSum[i] %= 10;}// 将数组进行前向赋值memcpy(numa, numb, sizeof(numb));memcpy(numb, numc, sizeof(numc));memcpy(numc, numd, sizeof(numd));}
}// 输出大数加法后的结果 
void printBigData()
{// 从最高位向后扫描,直到第 1 个非 0 数字出现 int p = N-1;while(preSum[p] == 0) p--;while(p > -1) cout<<preSum[p--];cout<<"\n";
} int main( )
{// 获取输入 int n;cin>>n;// 求出斐波那契数列 getFibonacci(n);// 输出前缀和 printBigData();return 0;
} 


MT2196 2的N次幂

难度:黄金    时间限制:1秒    占用内存:128M
题目描述

任意给定一个正整数 N ( N ≤ 100 ) N(N\le100) N(N100) ,计算 2 的 N N N 次方的值。

格式

输入格式:一个正整数 N N N
输出格式:输出 2 N 2^N 2N 的值。

样例 1

输入:5

输出:32


相关知识点:高精度计算


题解


2 n 2^n 2n n n n 取 100 时,是一个长度为 31 的大数,因此也是一道高精度题。与前面不同的是,这道题要求的是乘幂运算。但实际上,数的乘幂运算就等于进行 “幂” 次乘法运算(叠乘),乘数为底数。所以求解该题的关键实际是基于乘法运算的高精度计算问题,关于如何实现大数乘法运算的分析请见博客 【算法与数据结构】——大数运算 。

这里选用的数据结构依然是 int 型数组,其存储规则和大数加法一致(即低位对应较小的索引,高位对应较大的索引)。不过在算法一开始,需要将该数组的最低位置为底数(即 2)。接下来,定义一重循环(循环次数为 n − 1 n-1 n1),每遍都执行以下两步:

  • 将存放大数的数组中的每一位都乘以底数;
  • 遍历整个数组执行进位。

算法结束时,即得到了大数乘幂运算的结果。下面给出基于以上思路得到的完整代码:

/*MT2196 2的N次幂  
*/
#include<bits/stdc++.h> 
using namespace std;// 题目给的数据范围保证了结果不超过 32 位 
const int N = 32;
int num[N];// 高精度乘幂运算
void getHighPrecision(int base, int power)
{// 初始化存放运算结果的数组 memset(num, 0, sizeof(num));// 给数组赋初值 num[0] = base;// 执行乘幂运算 while(--power){// 将数组中的每个数进行乘法运算 for(int i=0; i<N; i++)num[i] *= base;// 对数组执行进位处理for(int i=0; i<N; i++){num[i+1] += num[i] / 10;num[i] %= 10;}}
}// 输出高精度运算后的大数
void printBigData()
{// 从最高位向后扫描,直到第 1 个非 0 数字出现 int p = N-1;while(num[p] == 0) p--;while(p > -1) cout<<num[p--];cout<<"\n";
} int main( )
{// 获取输入 int n;cin>>n;// 执行乘幂的高精度运算getHighPrecision(2, n);// 输出 printBigData();return 0;
} 

END


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

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

相关文章

【数值计算方法】导论

目录 一、极简数学史 1. 萌芽时期 2. 古典数学时期 3. 近代前期 4. 近代后期 5. 现代数学 二&#xff0c;计算方法学什么&#xff1f; 1. 数值代数 a. 线性代数方程组求解&#xff08;等价变换&#xff09; b. 矩阵特征值特征向量&#xff08;相似变换&#xff09; …

【附安装包】MyEclipse2019安装教程

软件下载 软件&#xff1a;MyEclipse版本&#xff1a;2019语言&#xff1a;简体中文大小&#xff1a;1.86G安装环境&#xff1a;Win11/Win10/Win8/Win7硬件要求&#xff1a;CPU2.5GHz 内存4G(或更高&#xff09;下载通道①百度网盘丨下载链接&#xff1a;https://pan.baidu.co…

Fiddler中 AutoResponder 使用

Fiddler的 AutoResponder &#xff0c;即URL重定向功能非常强大。不管我们做URL重定向&#xff0c;还是做mock测试等&#xff0c;都可以通过该功能进行实践。 下面&#xff0c;小酋就来具体讲下该功能的用法。 Enable rules 启用规则Unmatched requests passthrough 没有匹配…

electron globalShortcut 快捷键,在焦点移到其他软件上时,调用快捷键报错

用 electron 开发软件&#xff0c;在设置了 globalShortcut 快捷键后&#xff0c;在当前开发的软件上调用快捷键正常&#xff0c;但是当焦点不在当前软件时&#xff0c;在使用快捷键&#xff0c;好些时候会报错。大概率与系统快捷键产生冲突或者快键键控制的回调里获取的内容&a…

四信重磅推出5G RedCap AIoT摄像机 RedCap轻量级5G终端新品首发!

6月6日&#xff0c;四信受邀出席移动物联网高质量发展论坛&#xff0c;并在移动物联网新产品发布环节隆重推出5G RedCap AIoT摄像机&#xff0c;再次抓紧需求先机&#xff0c;为行业用户创造无限可能&#xff01; 两大应用场景 助推RedCap走深向实 火遍全网络的RedCap应用场景可…

java八股文面试[多线程]——ThreadLocal底层原理和使用场景

源码分析&#xff1a; ThreadLocal中定义了ThreadLocalMap静态内部类&#xff0c;该内部类中又定义了Entry内部类。 ThreadLocalMap定了 Entry数组。 Set方法&#xff1a; Get方法&#xff1a; Thread中定义了两个ThreaLocalMap成员变量&#xff1a; Spring使用ThreadLocal解…

Ansible学习笔记3

ansible模块&#xff1a; ansible是基于模块来工作的&#xff0c;本身没有批量部署的能力&#xff0c;真正具有批量部署的是ansible所运行的模块&#xff0c;ansible只是提供一个框架。 ansible支持的模块非常多&#xff0c;我们并不需要把每个模块记住&#xff0c;而只需要熟…

华为云软件精英实战营——感受软件改变世界,享受Coding乐趣

机器人已经在诸多领域显现出巨大的商业价值&#xff0c;华为云计算致力于以云助端的方式为机器人产业带来全新机会 如果您是开发爱好者&#xff0c;想了解华为云&#xff0c;想和其他自由开发者交流经验&#xff1b; 如果您是学生&#xff0c;想和正在从事软件开发行业的大佬…

Go 切片

切片 一、切片&#xff08;slice&#xff09;概念 在讲解切片&#xff08;slice&#xff09;之前&#xff0c;大家思考一下数组有什么问题&#xff1f; 数组定义完&#xff0c;长度是固定的。例如&#xff1a; var num [5]int [5]int{1,2,3,4,5}定义的num数组长度是5&#…

Android 下第一个fragment app 先Java 后Kotlin

看着视频学习的&#xff0c;Fragment&#xff1a;3.Fragment使用方法_哔哩哔哩_bilibili 在android studio 下新建一个工程&#xff0c;类型是 Empty View Activity&#xff0c;本身就有一个Activity。就有文件MainActivity.java 或者kt&#xff0c;还有一个layout 文件&#…

无代码:软件开发从代码语言到业务语言的拐点

在互联网巨头和中小企业纷纷追求移动互联和“上云”的今天&#xff0c;业务在线已成为众多企业数字化转型的必经之路。然而&#xff0c;传统的软件重装开发模式已经无法满足企业快速变化的需求&#xff0c;同时IT专业人才的成本也在不断攀升&#xff0c;使得企业的IT交付能力面…

Unity ShaderGraph教程——进阶shader

1.水面&#xff08;一&#xff09; 公式&#xff1a;场景深度 节点深度 — 屏幕空间位置的W向量 半透明物体与不透明物体的相交边缘 原理&#xff1a;场景深度 节点深度包含透明像素&#xff0c;屏幕空间w向量不包含透明像素。 注意&#xff1a;需要在UniversalRP-xxxQuali…

Docker修改容器ulimit的全部方案及各方案的详细步骤

要修改Docker容器的ulimit&#xff08;用户资源限制&#xff09;&#xff0c;有以下三种方案&#xff0c;每个方案的详细步骤如下&#xff1a; 方案一&#xff1a;在Dockerfile中设置ulimit 打开您的Dockerfile。在文件中添加以下命令来修改ulimit&#xff1a;RUN ulimit -n …

Mysql索引、事务与存储引擎 (事务、MySQL 存储引擎)

事务 一、事务的概念&#xff1a; ①事务是一种机制、一个操作序列&#xff0c;包含了一组数据库操作命令&#xff0c;并且把所有的命令作为一个整体一起向系统提交或撤销操作请求&#xff0c;即这一组数据库命令要么都执行&#xff0c;要么都不执行。 ②事务是一个不可分割的工…

海康机器人工业相机SDK MVS安装教程

文章目录 一. 海康机器人介绍二. 工业相机客户端安装教程 一. 海康机器人介绍 海康机器人是面向全球的机器视觉和移动机器人产品及解决方案提供商&#xff0c;业务聚焦于工业物联网、智慧物流和智能制造&#xff0c;构建开放合作生态&#xff0c;为工业和物流领域用户提供服务…

对分库分表进行批量操作

对ShardingJDBC基础了解&#xff1a;https://blog.csdn.net/m0_63297646/article/details/131894472 对批量操作案例&#xff1a;https://blog.csdn.net/m0_63297646/article/details/131843517 分为db0和db1两个库&#xff0c;每个库都有三张订单表&#xff0c;分表键根据年份…

如何自定义iview树形下拉内的内容

1.使用render函数给第一层父级定义 2. 使用树形结构中的render函数来定义子组件 renderContent(h, {root, node, data}) {return data.children.length0? h(span, {style: {display: inline-block,width: 400px,lineHeight: 32px}}, [h(span, [h(Icon, {type: ios-paper-outli…

解密数据分析:提升企业竞争力的关键一步

在当今数字化时代&#xff0c;数据已成为企业最宝贵的资产之一。数据分析作为一项强大的工具&#xff0c;对企业来说已经不再是可选项&#xff0c;而是一项必不可少的战略性举措。为什么企业要做数据分析&#xff1f;让我们深入探讨这个问题。 提升决策质量&#xff1a; 数据…

TiDB Serverless Branching:通过数据库分支简化应用开发流程

2023 年 7 月 10 日&#xff0c;TiDB Serverless 正式商用。这是一个完全托管的数据库服务平台&#xff08;DBaaS&#xff09;&#xff0c;提供灵活的集群配置和基于用量的付费模式。紧随其后&#xff0c;TiDB Serverless Branching 的测试版也发布了。 TiDB Serverless Branc…