高精度计算(代码加解析,洛谷p1601,p1303)除法待更新

2024-09-08 01:28

本文主要是介绍高精度计算(代码加解析,洛谷p1601,p1303)除法待更新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

高精度加法

高精度减法

高精度乘法


高精度加法

我们知道在c++语言中任何数据类型都有一定的表示范围。当两个被加数很大时,正常加法不能得到精确解。在小学,我们做加法都采用竖式方法。那么我们也只需要按照加法进位的方式就能得到最终解。

  8 5 6
+ 2 5 5
-------
1 1 1 1

加法进位:

c[i] = a[i] + b[i];
if(c[i] >= 10){c[i] %= 10;c[i+1]++;
}

按位相加求和:

    int len = s1.length();int carry = 0;for(int i = len-1; i >= 0; i--){int tmp = s1[i] - '0' + s2[i] - '0' + carry;carry = tmp/10;tmp %= 10;ret = char(tmp + '0') + ret;}if(carry != 0) ret = char(carry + '0') + ret;

 完整代码:

#include<iostream>
#include<string>
using namespace std;int main()
{string s1,s2,ret;cin >> s1 >> s2;int len1 = s1.length();int len2 = s2.length();// 不论s1,s2谁短,高位补0补到一样长if(len1<len2){for(int i=1;i<=len2-len1;i++)s1="0"+s1;}else{for(int i=1;i<=len1-len2;i++)s2="0"+s2;}int len = s1.length();  //得到两个字符串的长度int carry = 0;  // 记录进位// i从字符串最后一位向前走,也就是从两个数的个位向高位走for(int i = len-1; i >= 0; i--){// 相当于c[i] = a[i] + b[i],如果c[i]>=10, c[i]%=10, c[i+1]++;int tmp = s1[i] - '0' + s2[i] - '0' + carry; //字符转换成数字,要-'0'carry = tmp/10;tmp %= 10;ret = char(tmp + '0') + ret; //把每个新位放到原字符串前面}//如果carry位不等于0,则表明两个数的最高位相加还有进位if(carry != 0) ret = char(carry + '0') + ret;  cout << ret;
}

高精度减法

类似加法,也可以用竖式求解。需要注意的是,被减数必须比减数大,同时需要处理借位。

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int main()
{int a[256],b[256],c[256],lena,lenb,lenc,i;char n[256],n1[256],n2[256];memset(a,0,sizeof(a));memset(b,0,sizeof(b));memset(c,0,sizeof(c));printf("Input minuend:");	gets(n1);printf("Input subtrahend:");	gets(n2);if(strlen(n1) < strlen(n2) || (strlen(n1) == strlen(n2) && strcmp(n1,n2) < 0)){strcpy(n,n1);strcpy(n1,n2);strcpy(n2,n);cout << "-"; 	//因为交换了减数和被减数,结果为负数 }lena = strlen(n1);lenb = strlen(n2);for(i = 0; i <= lena-1; i++) a[lena-i] = int(n1[i] - '0');	//被减数放入a数组 for(i = 0; i <= lenb-1; i++) b[lenb-i] = int(n2[i] - '0');	//减数放入b数组i= 1;while(i <= lena || i <= lenb){if(a[i] < b[i]){a[i]+=10;	//高位借1 a[i+1]--;}c[i] = a[i] - b[i];	//对应位相减i++; } lenc = i;while(c[lenc] == 0 && lenc > 1) lenc--;	//最高位0不输出for(i = lenc; i >= 1; i--) cout << c[i];cout << endl;return 0; 
}

高精度乘法

类似加法,可以用竖式求乘法。在做乘法运算时,同样也有进位。同时对每一位进行乘法运算时,必须进行错位相加。

     8  5  6
*       2  5 
----------------4  2  8  0
1 7  1  2
----------------
2 1  4  0  0
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int main()
{char a1[101],b1[101];int a[101],b[101],c[10001],lena,lenb,lenc,i,j,x;memset(a,0,sizeof(a));memset(b,0,sizeof(b));memset(c,0,sizeof(c));scanf("%s",a1);scanf("%s",b1);lena = strlen(a1); lenb = strlen(b1);for(i = 0; i <= lena-1; i++) a[lena-i] = int(a1[i] - 48);	for(i = 0; i <= lenb-1; i++) b[lenb-i] = int(b1[i] - 48);	for(i = 1; i <= lena; i++){x = 0;for(j = 1; j <= lenb; j++){c[i+j-1] += a[i]*b[j] + x;	//当前乘机+上次乘机进位+原数 x = c[i+j-1] / 10;c[i+j-1] %= 10;}c[i+lenb] = x;	//进位 } lenc = lena + lenb;while(c[lenc] == 0 && lenc > 1)	lenc--;	//删除前导0 for(i = lenc; i > 0; i--) cout << c[i];cout << endl; return 0; 
}

还有一种思路,把每一位的乘积和加起来先不做处理。最后再去处理计算进位。

        7    8    9
*            2    3
----------------------21   24    2714   16   18
----------------------14   37   42    271 (1) 8 (4) 1 (4) 4 (2) 7

这篇关于高精度计算(代码加解析,洛谷p1601,p1303)除法待更新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

Redis过期删除机制与内存淘汰策略的解析指南

《Redis过期删除机制与内存淘汰策略的解析指南》在使用Redis构建缓存系统时,很多开发者只设置了EXPIRE但却忽略了背后Redis的过期删除机制与内存淘汰策略,下面小编就来和大家详细介绍一下... 目录1、简述2、Redis http://www.chinasem.cn的过期删除策略(Key Expir

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析

《Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析》InstantiationAwareBeanPostProcessor是Spring... 目录一、什么是InstantiationAwareBeanPostProcessor?二、核心方法解

深入解析 Java Future 类及代码示例

《深入解析JavaFuture类及代码示例》JavaFuture是java.util.concurrent包中用于表示异步计算结果的核心接口,下面给大家介绍JavaFuture类及实例代码,感兴... 目录一、Future 类概述二、核心工作机制代码示例执行流程2. 状态机模型3. 核心方法解析行为总结:三

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

springboot项目中使用JOSN解析库的方法

《springboot项目中使用JOSN解析库的方法》JSON,全程是JavaScriptObjectNotation,是一种轻量级的数据交换格式,本文给大家介绍springboot项目中使用JOSN... 目录一、jsON解析简介二、Spring Boot项目中使用JSON解析1、pom.XML文件引入依

Python中文件读取操作漏洞深度解析与防护指南

《Python中文件读取操作漏洞深度解析与防护指南》在Web应用开发中,文件操作是最基础也最危险的功能之一,这篇文章将全面剖析Python环境中常见的文件读取漏洞类型,成因及防护方案,感兴趣的小伙伴可... 目录引言一、静态资源处理中的路径穿越漏洞1.1 典型漏洞场景1.2 os.path.join()的陷

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L