C++高精度算法的使用场景详解

目录
  • 描述
  • 1. 高精度加法
    • 1. 思路
    • 2. 代码
  • 2. 高精度减法
    • 1. 思路
    • 2. 代码
    • 3. 如果出现被减数的位数小于减数时呢

描述

如果要计算的数超过了long long怎么解决? —>使用高精度加减乘除,简单理解就是 很大的数进行加减乘除。

1. 高精度加法

1. 思路

  • 创建对应的数组变量及其他变量
  • 输入字符串
  • 将读入的数据转化为整数类型,并逆序(反转)存储到数组中
  • 将两个数组做累加(注意进位)
  • 判断最高位是否为0,大于0代表进位了,则让长度加1
  • 倒序输出

2. 代码

#include<bits/stdc++.h>
using namespace std;
int a[510], b[510], c[510];//a:被加数  b:加数  c:和
int main(){
	// 1. 输入字符串
    string str1,str2;
    cin >> str1 >> str2;
    // 2. "1,2,3,4"转换为{1,2,3,4},并且反转 {4,3,2,1}
    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';
	// 3. 找两个字符串最大的个数,目的是为了将每一位计算完
    int ans = max(str1.size(), str2.size());
    // 4. 相加(a+b)
    for (int i = 0; i < ans; i ++){//遍历至最大长度,避免有的数字没计算
        c[i] += a[i] + b[i];//相加
        c[i+1] = c[i] / 10;// 进位
        c[i] %= 10;//将加的结果求余10 得出第i位
    }
    //4. 如果结果数组第ans位的数大于0(大于0代表进位了),则让长度增加1
    while(c[ans]>0) ans++;
    //5. 倒序输出
    for (int i = ans-1; i >= 0; i--)
        cout << c[i];
    return 0;
}
#include<bits/stdc++.h>
using namespace std;
int a[500],b[500],c[501],ans[501],len_a,len_b,len_ans;//a:加数1  b:加数2  c:进位数组  ans:结果数组
int main(){
	// 1. 输入字符串
    string str1,str2;
    cin >> str1 >> str2;
	len_a = str1.length();
	len_b = str2.length();
    // 2. "1,2,3,4"转换为{1,2,3,4},并且反转 {4,3,2,1}
    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';
	// 3. 找两个字符串最大的个数,目的是为了将每一位计算完
	len_ans = max(len_a,len_b);
	// 4. 相加(a+b)
	for(int i=0;i<=len_ans;i++){
		ans[i] = a[i] + b[i] + c[i];//结果数组 =(等于) 被加数 加上  加数 加上 进位的数
		if(ans[i] > 9){//如果结果数组大于9,则进位
			c[i+1] = ans[i] / 10;//给进位数组赋值
			ans[i] %= 10; // 让结果数组大于9的数求余10,变成个位数
		}
	}
	//5. 如果结果数组len_ans位的数大于0,则让长度增加1
	while(ans[len_ans]>0) len_ans++;
	//6. 倒叙输出
	for(int i=len_ans-1;i>=0;i--) cout<<ans[i];
	return 0;
}

2. 高精度减法

1. 思路

  • 定义被减数a,减数b,结果c数组
  • 输入被减数和减数,并且将数据倒叙存入数组中。
  • 找两个字符串最大的个数,目的是为了将每一位计算完
  • 将两个数组做相减(遍历至最大长度,避免有的数字没计算 )。
  • 去掉前导 0 。例如结果为:089,不需要0
  • 循环遍历输出

2. 代码

#include<bits/stdc++.h>
using namespace std;
int a[510], b[510], c[510];//a:被减数  b:减数  c:结果
int main(){
	// 1. 输入字符串
    string str1,str2;
    cin >> str1 >> str2;
    // 2. "1,2,3,4"转换为{1,2,3,4},并且反转 {4,3,2,1}
    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';
	// 3. 找两个字符串最大的个数,目的是为了将每一位计算完
    int ans = max(str1.size(), str2.size());
    // 4. 相减(a-b)
    for (int i = 0; i < ans; i ++){//遍历至最大长度,避免有的数字没计算
    	if(a[i] < b[i]){
        	a[i+1] -= 1;//向前借一位
        	a[i] += 10;// 借一位以后加10
		}
        c[i] = a[i] - b[i];
    }
    //5. 如去掉前导 0 。例如结果为:089,不需要0
    while(c[ans-1]==0 && ans>1) ans--;
    //6. 倒序输出
    for (int i = ans-1; i >= 0; i--)
        cout << c[i];
    return 0;
}
#include<bits/stdc++.h>
using namespace std;
int a[500],b[500],c[501],ans[501],len_a,len_b,len_ans;//a:被减数  b:减数  c:进位  ans:结果
int main(){
	// 1. 输入字符串
    string str1,str2;
    cin >> str1 >> str2;
	len_a = str1.length();
	len_b = str2.length();
    // 2. "1,2,3,4"转换为{1,2,3,4},并且反转 {4,3,2,1}
    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';
	// 3. 找两个字符串最大的个数,目的是为了将每一位计算完
	len_ans = max(len_a,len_b);
	// 4. 相减(a-b)
	for(int i=0;i<=len_ans;i++){
		ans[i] = a[i] - b[i] - c[i];//结果数组 =(等于) 被减数 减去  减数  减去 进位的数
		if(ans[i] < 0){//如果结果数组小于0,则借位
			ans[i] += 10;// 借1位,加上10
			c[i+1]++;    // 进位数组加1
		}
	}
	//5. 如去掉前导 0 。例如结果为:089,不需要0
	while(len_ans>1 && ans[len_ans-1]==0) len_ans--;
	//6. 倒序输出
	for(int i=len_ans-1;i>=0;i--) cout<<ans[i];
	return 0;
}

3. 如果出现被减数的位数小于减数时呢

#include<bits/stdc++.h>
using namespace std;
int a[510], b[510], c[510];//a:被减数  b:减数   c:结果
int flag = 0;
int main(){
	// 1. 输入字符串
    string str1,str2;
    cin >> str1 >> str2;
    //2. str1.size() < str2.size() 或者 两个数一样长并且被减数的数值小于减数时,才需要交换两数位置
    if(str1.size() < str2.size() || str1.size() == str2.size() && str1 < str2) {
    	string t = str1;
    	str1 = str2;
    	str2 = t;
    	flag = 1;
	}
    // 3. "1,2,3,4"转换为{1,2,3,4},并且反转 {4,3,2,1}
    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';
	// 4. 找两个字符串最大的个数,目的是为了将每一位计算完
    int ans = max(str1.size(), str2.size());
    // 5. 相减(a-b)
    for (int i = 0; i < ans; i ++){//遍历至最大长度,避免有的数字没计算
    	if(a[i] < b[i]){
        	a[i+1] -= 1;//向前借一位
        	a[i] += 10;// 借一位以后加10
    	}
		c[i] = a[i] - b[i];
    }
    //6.如去掉前导 0 。例如结果为:089,不需要0
    while(c[ans-1]==0 && ans>1) ans--;
    //7. 倒叙输出
    if(flag == 1) cout<<"-";
    for (int i = ans-1; i >= 0; i--)
        cout << c[i];
    return 0;
}

到此这篇关于C++高精度算法的使用场景详解的文章就介绍到这了,更多相关C++高精度算法内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • c++实现高精度加法

    最近遇到一个c++实现高精度加法的问题,高精度问题往往十复杂但发现其中的规律后发现并没有那么复杂,这里我实现了一个整数的高精度加法,主要需要注意以下几点: 1:将所需输入的数据以字符数组的形式输入,建立字符数组,建立相应的整数数组,然后一一映射,以此来实现数据的输入,需要注意的是,当实现字符向数字映射时,应该减去相应的ASCII偏移值,即48. 2:为了模拟我们在纸上手算的进位模拟运算,我们将字符数组反向填入整数数组,上图的后几行代码实现了这个操作. 3:实现进位加法,这是整个代码的核心部分,需

  • C/C++高精度算法的实现

    做ACM题的时候,经常遇到大数的加减乘除,乘幂,阶乘的计算,这时给定的数据类型往往不够表示最后结果,这时就需要用到高精度算法.高精度算法的本质是把大数拆成若干固定长度的块,然后对每一块进行相应的运算.这里以考虑4位数字为一块为例,且输入的大数均为正整数(也可以考虑其他位,但要注意在每一块进行相应运算时不能超出数据类型的数值范围:有负整数的话读入时判断一下正负号在决定运算). 1. 高精度加法 以3479957928375817 + 897259321544245为例: 3479 9579 283

  • 使用C++的string实现高精度加法运算的实例代码

    对于超大数字的运算,用long long int仍然不能解决,这时候就需要考虑通过模拟运算和数组存储来实现高精度运算. 本文讨论借助C++的string来实现高精度的运算. 首先输入的量直接存储为string,设为s1和s2. 接下来设计一个反转函数,用于把整个字符串反转(为了方便后续计算). string reverseStr(string input){ string output = ""; for(int i = 0; i < input.length(); i++){

  • c++加法高精度算法的简单实现

    c++高精度算法,对于新手来说还是一大挑战,只要克服它,你就开启了编程的新篇章,算法. 我发的这个代码并不是很好,占用内存很多而且运行时间很长(不超过1秒),但是很好理解,很适合新手 高精算法的本质就是把数组编程字符串,然后将字符串像竖式一样加起来: a+b高精度算法 #include <iostream> #include <cmath> #include <cstring> using namespace std; int main() { char a[10001

  • C++高精度算法的使用场景详解

    目录 描述 1. 高精度加法 1. 思路 2. 代码 2. 高精度减法 1. 思路 2. 代码 3. 如果出现被减数的位数小于减数时呢 描述 如果要计算的数超过了long long怎么解决? —>使用高精度加减乘除,简单理解就是 很大的数进行加减乘除. 1. 高精度加法 1. 思路 创建对应的数组变量及其他变量 输入字符串 将读入的数据转化为整数类型,并逆序(反转)存储到数组中 将两个数组做累加(注意进位) 判断最高位是否为0,大于0代表进位了,则让长度加1 倒序输出 2. 代码 #includ

  • java图论普利姆及克鲁斯卡算法解决最小生成树问题详解

    目录 什么是最小生成树? 普利姆算法  算法介绍 应用 --> 修路问题  图解分析  克鲁斯卡尔算法 算法介绍 应用场景 -- 公交站问题  算法图解   算法分析  如何判断是否构成回路 什么是最小生成树? 最小生成树(Minimum Cost Spanning Tree),简称MST. 最小生成树要求图是连通图.连通图指图中任意两个顶点都有路径相通,通常指无向图.理论上如果图是有向.多重边的,也能求最小生成树,只是不太常见. 普利姆算法  算法介绍 应用 --> 修路问题  图解分析 

  • java数据结构算法稀疏数组示例详解

    目录 一.什么是稀疏数组 二.场景用法 1.二维数组转稀疏数组思路 2.稀疏数组转二维数组思路 3.代码实现 一.什么是稀疏数组 当一个数组a中大部分元素为0,或者为同一个值,那么可以用稀疏数组b来保存数组a. 首先,稀疏数组是一个数组,然后以一种特定的方式来保存上述的数组a,具体处理方法: 记录数组a一共有几行几列 记录a中有多少个不同的值 最后记录不同值的元素所在行列,以及具体的值,放在一个小规模的数组里,以缩小程序的规模. 这个小规模的数组,就是稀疏数组. 举个栗子,左侧是一个二维数组,一

  • TypeScript实现十大排序算法之冒泡排序示例详解

    目录 一. 冒泡排序的定义 二. 冒泡排序的流程 三. 冒泡排序的图解 四. 冒泡排序的代码 五. 冒泡排序的时间复杂度 六. 冒泡排序的总结 一. 冒泡排序的定义 冒泡排序是一种简单的排序方法. 基本思路是通过两两比较相邻的元素并交换它们的位置,从而使整个序列按照顺序排列. 该算法一趟排序后,最大值总是会移到数组最后面,那么接下来就不用再考虑这个最大值. 一直重复这样的操作,最终就可以得到排序完成的数组. 这种算法是稳定的,即相等元素的相对位置不会发生变化. 而且在最坏情况下,时间复杂度为O(

  • JAVA 中解密RSA算法JS加密实例详解

    JAVA 中解密RSA算法JS加密实例详解 有这样一个需求,前端登录的用户名密码,密码必需加密,但不可使用MD5,因为后台要检测密码的复杂度,那么在保证安全的前提下将密码传到后台呢,答案就是使用RSA非对称加密算法解决 . java代码 需要依赖 commons-codec 包 RSACoder.Java import org.apache.commons.codec.binary.Base64; import javax.crypto.Cipher; import java.security.

  • 浅谈js-FCC算法Friendly Date Ranges(详解)

    让日期区间更友好! 把常见的日期格式如:YYYY-MM-DD 转换成一种更易读的格式. 易读格式应该是用月份名称代替月份数字,用序数词代替数字来表示天 (1st 代替 1). 记住不要显示那些可以被推测出来的信息: 如果一个日期区间里结束日期与开始日期相差小于一年,则结束日期就不用写年份了.月份开始和结束日期如果在同一个月,则结束日期月份就不用写了. 另外, 如果开始日期年份是当前年份,且结束日期与开始日期小于一年,则开始日期的年份也不用写. 我的代码: function makeFriendl

  • java 算法之冒泡排序实例详解

    java 算法之冒泡排序实例详解 无人不知无人不晓的冒泡排序,据说是模仿泡泡从水中浮起跑到水面的过程. 在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒.即: 每当两相邻的数比较后发现它们的排序与排序要求相反时,就将它们互换. 来看一下代码: package cn.songxinqiang.study.algorithm.sort; import java.util.Arrays; /** * 冒泡排序 * * <p>

  • 机器学习经典算法-logistic回归代码详解

    一.算法简要 我们希望有这么一种函数:接受输入然后预测出类别,这样用于分类.这里,用到了数学中的sigmoid函数,sigmoid函数的具体表达式和函数图象如下: 可以较为清楚的看到,当输入的x小于0时,函数值<0.5,将分类预测为0:当输入的x大于0时,函数值>0.5,将分类预测为1. 1.1 预测函数的表示 1.2参数的求解 二.代码实现 函数sigmoid计算相应的函数值:gradAscent实现的batch-梯度上升,意思就是在每次迭代中所有数据集都考虑到了:而stoGradAscen

  • Volley源码之使用方式和使用场景详解

    概述 Volley是Google在2013年推出的一个网络库,用于解决复杂网络环境下网络请求问题.刚推出的时候是非常火的,现在该项目的变动已经很少了.项目库地址为https://android.googlesource.com/platform/frameworks/volley 通过提交历史可以看到,最后一次修改距离今天已经有一段时间了.而volley包的release版本也已经很久没有更新了. author JeffDavidson<jpd@google.com> SunMar1316:3

  • JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

    排序算法的介绍 排序也称排序算法 (Sort Algorithm),排序是将 一组数据 , 依指定的顺序 进行 排列的过程 . 排序的分类 1)  内部排序 : 指将需要处理的所有数据都加载 到 内部存储器(内存) 中进行排序. 2) 外部排序法: 数据量过大,无法全部加载到内 存中,需要借助 外部存储(文件等) 进行 排序. 常见的排序算法分类 算法的时间复杂度 度量一个程序(算法)执行时间的两种方法 1.事后统计的方法 这种方法可行, 但是有两个问题:一是要想对设计的算法的运行性能进行评测,

随机推荐