秒懂百科,C++如此简单丨第十八天:高精度

2024-02-14 01:04

本文主要是介绍秒懂百科,C++如此简单丨第十八天:高精度,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

前言 

模拟运算

高精度加法模版

优化

高精度减法模版

高精度乘法模版

结尾


 必看信息 

▶本篇文章由爱编程的小芒果原创,首发于CSDN,未经许可,严禁转载。

▶本篇文章被收录于秒懂百科,C++如此简单专栏,欢迎订阅。

☆专栏亮点☆

1.每篇文章质量高,质量分保证在80分以上。

2.文章的内容清晰有条理,图文并茂,附有源代码。

3.每个知识点讲解详细,会有很多补充扩展。

4.若哪个知识点没有懂,可以私信我,我会尽可能地帮助你。

前言 

在编程中,我们常常会遇到一些极大的数字。这些数字用long long和double是根本存不下的,所以这节课我们将介绍高精度。

模拟运算

高精度说白了就是模拟运算,首先我们先想一想在生活中我们是怎样计算整数加法的。

12345
+78765
=91110

在计算的过程中,我们会遇到一个特殊情况——进位。

如在计算个位的时候,5+5=10,写0进1,十位4+6+1=11,写1进1。

遇到这种情况该怎么办呢?因为我们知道一个原则“满十进一” ,那么两个数相加在一起一共有多少个整十,是不是就要进几?如8+9=17,有一个整十,所以要进一,以此类推。

而判断一个数由多少个整十最好的方法就是——除法,我们用一个数除以10,得到的就是一个数由几个十组成,注意:这里因为是整数,所以除法是会保留整数,而一个数对10取余不就是余下来的几个一吗?思路知道了,程序也就简单了。

高精度加法模版

#include<bits/stdc++.h>
using namespace std;  
const int N=510; //定义足够大的数组来存储大整数的每一位  
int a[N],b[N],c[N];  
int main() 
{  string str1,str2;  cin>>str1>>str2;// 将字符串逆序存储到数组中,方便从低位到高位进行加法运算  for (int i = 0; i < str1.size(); i++)  a[str1.size() - 1 - i] = str1[i] - '0';  for (int i = 0; i < str2.size(); i++)  b[str2.size() - 1 - i] = str2[i] - '0';  //确定最大长度  int len = max(str1.size(), str2.size());  //进行高精度加法运算  for (int i = 0; i < len; i++) {  c[i] += a[i] + b[i];  c[i + 1] += c[i] / 10; //进位  c[i] %= 10; //取当前位的值  }  //处理最高位的进位  if (c[len] > 0) {  len++; //如果最高位有进位,则长度加1  }  //逆序输出结果  for (int i = len - 1; i >= 0; i--) {  cout << c[i];  }  return 0;  
}

优化

因为我们知道两个数相加最多是18(9+9),那么进位最多是1,所以进位也可以写成这样。

for (int i = 0; i < len; i++) 
{  c[i] += a[i] + b[i];  if(c[i]>=10) {c[i]-=10;c[i+1]+=1;} 
}  

高精度减法模版

高精度减法只需要把“进位”修改成“退位”即可。但需要注意以下几点:

1.判断正负数,如果A<B需要先输出一个负号,并交换A和B。

2.需要借位,千万不要写成进位了。

3.前导零可能不止一个,不要用if,用while循环。

4.如果答案为0,记得额外输出一个0。

#include<bits/stdc++.h>  
using namespace std;  
const int N=510;  
int a[N],b[N],c[N];  
int main() 
{  string str1, str2;  cin >> str1 >> str2;  // 确保str1 >= str2,这里不处理str1 < str2的情况  if (str1.size() < str2.size() || (str1.size() == str2.size() && str1 < str2)) {  cout << "-" << endl; // 输出负号,实际应用中需要更完整的处理  swap(str1, str2); // 交换两个字符串,使得str1始终为较大的数  }  // 将字符串逆序存储到数组中  for (int i = 0; i < str1.size(); i++) a[str1.size() - 1 - i] = str1[i] - '0';  for (int i = 0; i < str2.size(); i++) b[str2.size() - 1 - i] = str2[i] - '0';  int len = max(str1.size(), str2.size());  for (int i = 0; i < len; i++) {  if (a[i] < b[i]) { // 需要借位  a[i + 1]--; // 从高位借1  a[i] += 10; // 当前位加10  }  c[i] = a[i] - b[i]; // 进行减法运算  }  // 跳过前导零  int start = len - 1;  while (start >= 0 && c[start] == 0) {  start--;  }  // 输出结果  if (start >= 0) {  for (int i = start; i >= 0; i--) {  cout << c[i];  }  } else {  cout << "0"; // 如果结果为0,则输出0  }  return 0;  
}

高精度乘法模版

注意以下几点:
1.乘法的每一数位都要和另一个数的每一数位相乘。

2.注意数组c不要开太小了。

#include<bits/stdc++.h>  
using namespace std;  
const int N=510; // 数组大小,用于存储大整数的每一位  
int a[N],b[N],c[N*2]; // c数组的大小为2*N,因为两个N位数相乘的结果可能接近2N位  
int main() 
{  string str1, str2;  cin >> str1 >> str2;  // 将字符串逆序存储到数组中,方便从低位到高位进行计算  for (int i = 0; i < str1.size(); i++) a[str1.size() - 1 - i] = str1[i] - '0';  for (int i = 0; i < str2.size(); i++) b[str2.size() - 1 - i] = str2[i] - '0';  // 高精度乘法  memset(c, 0, sizeof(c)); // 初始化c数组为0  for (int i = 0; i < str1.size(); i++) {  for (int j = 0; j < str2.size(); j++) {  c[i + j] += a[i] * b[j]; // 计算乘积并加到对应位置  c[i + j + 1] += c[i + j] / 10; // 处理进位  c[i + j] %= 10; // 取当前位的值  }  }  // 跳过前导零  int start = str1.size() + str2.size() - 1;  while (start >= 0 && c[start] == 0) {  start--;  }  // 输出结果  if (start >= 0) {  for (int i = start; i >= 0; i--) {  cout << c[i];  }  } else {  cout << "0"; // 如果结果为0,则输出0  }  return 0;  
}

结尾

本节课我们一起学习了高精度,还有高精度除法没有写,留给你自己写一写吧。

如果你觉得还不错的话,记得点赞收藏评论哦,下课!

这篇关于秒懂百科,C++如此简单丨第十八天:高精度的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/707110

相关文章

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

C++中实现调试日志输出

《C++中实现调试日志输出》在C++编程中,调试日志对于定位问题和优化代码至关重要,本文将介绍几种常用的调试日志输出方法,并教你如何在日志中添加时间戳,希望对大家有所帮助... 目录1. 使用 #ifdef _DEBUG 宏2. 加入时间戳:精确到毫秒3.Windows 和 MFC 中的调试日志方法MFC

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

使用PyQt5编写一个简单的取色器

《使用PyQt5编写一个简单的取色器》:本文主要介绍PyQt5搭建的一个取色器,一共写了两款应用,一款使用快捷键捕获鼠标附近图像的RGB和16进制颜色编码,一款跟随鼠标刷新图像的RGB和16... 目录取色器1取色器2PyQt5搭建的一个取色器,一共写了两款应用,一款使用快捷键捕获鼠标附近图像的RGB和16

四种简单方法 轻松进入电脑主板 BIOS 或 UEFI 固件设置

《四种简单方法轻松进入电脑主板BIOS或UEFI固件设置》设置BIOS/UEFI是计算机维护和管理中的一项重要任务,它允许用户配置计算机的启动选项、硬件设置和其他关键参数,该怎么进入呢?下面... 随着计算机技术的发展,大多数主流 PC 和笔记本已经从传统 BIOS 转向了 UEFI 固件。很多时候,我们也

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核