高精度算法模板

1.加法


string  a1, b1;
int a[5010], b[5010], c[5010];
signed main() {cin >> a1 >> b1;int len1 = a1.size();int len2 = b1.size();for (int i = 1; i <= len1; i++) {a[i] = a1[len1 - i] - '0';}for (int i = 1; i <= len2; i++) {b[i] = b1[len2 - i] - '0';}for (int i = 1; i <= max(len1, len2); i++) {c[i] += a[i] + b[i];c[i + 1] = c[i] / 10;c[i] %= 10;}if (c[max(len1, len2) + 1] != 0) cout << c[max(len1, len2) + 1];for (int i = max(len1, len2); i >= 1; i--) {cout << c[i];}return 0;
}

2.减法

#include<set>
#include<list>
#include<queue>
#include<math.h>
#include<stdlib.h>
#include<string>
#include<string.h>
#include <stdio.h>
#include<algorithm>
#include<iomanip>
#include<cmath>
#include<sstream>
#include<stack>
#include <utility>
#include<map>
#include <vector>#define inf 0x3f3f3f3f
#define int long long
const int N =1e6 + 10;
//#include <bits/stdc++.h>
typedef long long ll;
#include<iostream>
using namespace std;//long long MAX(long long a, long long b) { return a < b ? b : a; }string  a1, b1;
int a[N], b[N], c[N];
bool cmp(string e1, string e2) {int len1 = e1.size();int len2 = e2.size();if (len1 > len2) return true;//e1比e2大else {for (int i = len1 - 1; i >= 0; i--) {if (e2[i] > e1[i]) return false;}}return true;//一样大
}
signed main() {cin >> a1 >> b1;int f = 0;if (!cmp(a1, b1)) {//b比a大swap(a1, b1);f = 1;}for (int i = 1; i <= a1.size(); i++) {a[i] = a1[a1.size() - i] - '0';}for (int i = 1; i <= b1.size(); i++) {b[i] = b1[b1.size() - i] - '0';}int cnt = 0;for (int i = 1; i <= max(a1.size(),b1.size()); i++) {if (a[i] < b[i]) {a[i] += 10;a[i + 1] -= 1;}c[i] = a[i] - b[i];}if (f) cout << "-";int lc = max(a1.size(), b1.size());while (c[lc] == 0 && lc > 1) lc--;//去除前导0for (int i = lc; i >= 1; i--) {cout << c[i];}return 0;
}

3.乘法

string  a1, b1;
int a[N], b[N], c[N];signed main() {cin >> a1 >> b1;int la = a1.size();int lb = b1.size();for (int i = 1; i <= la; i++) {a[i] = a1[a1.size() - i] - '0';}for (int i = 1; i <= lb; i++) {b[i] = b1[b1.size() - i] - '0';}int lc = la + lb;//乘积的最长长度for (int i = 1; i <= la; i++) {for (int j = 1; j <= lb; j++) {c[i + j - 1] += a[i] * b[j];c[i + j] += c[i + j - 1] / 10;c[i + j - 1] %= 10;}}while (lc > 1 && c[lc] == 0) lc--;for (int i = lc; i >= 1; i--) cout << c[i];return 0;
}

4.除法

高精度除以低精度

模拟试除法

#include<set>
#include<list>
#include<queue>
#include<math.h>
#include<stdlib.h>
#include<string>
#include<string.h>
#include <stdio.h>
#include<algorithm>
#include<iomanip>
#include<cmath>
#include<sstream>
#include<stack>
#include <utility>
#include<map>
#include <vector>#define inf 0x3f3f3f3f
#define int long long
const int N =1e6 + 10;
//#include <bits/stdc++.h>
typedef long long ll;
#include<iostream>
using namespace std;//long long MAX(long long a, long long b) { return a < b ? b : a; }string  a1;
int a[N], b, c[N];signed main() {cin >> a1 >> b;int la = a1.size();for (int i = 1; i <= la; i++) {a[i] = a1[i - 1] - '0';}int cur = 0;//余数for (int i = 1; i <= la; i++) {c[i] = (cur * 10 + a[i]) / b;cur = (cur * 10 + a[i]) % b;}int lc = 1;while (c[lc] == 0 && lc < la) lc++;//最终的结果位数至少是1位数,所以lc不能大于lafor (int i = lc; i <= la; i++) cout << c[i];return 0;
}

高精度除以高精度

#include <cstdio>
#include <iostream>
#include <cstring>using namespace std;int a[50005], b[50005], c[50005], d;void init(int a[]) {char s[50005];cin >> s;a[0] = strlen(s);		// 字符串存储,表示位数	for (int i=1; i<=a[0]; i++) {a[i] = s[a[0]-i] - 48;	// 正序储存} 	
}void print(int a[]) {			if (a[0] == 0) {cout << 0 << endl;return;  // 位数为0,输出0}for (int i=a[0]; i>=1; i--) {cout << a[i];  // 输出函数}cout << endl;return;
} int compare(int a[], int b[]) {	if (a[0] > b[0]) {return 1; // 被减数大于减数} if (a[0] < b[0]) {return -1; // 被减数小于减数}for (int i=a[0]; i>=1; i--) {	if (a[i] > b[i]) {return 1;} if (a[i] < b[i]) {return -1;}   // 位数相同,找到第一位不同的进行比较} return 0;					
}void numcpy(int p[], int q[], int det) {for (int i=1; i<=p[0]; i++) {q[i+det-1] = p[i]; //复制p数组到q数组从det开始的地方}q[0] = p[0] + det - 1;
}void jian(int a[], int b[]) {		int flag = compare(a, b);		 if (flag == 0)  {					a[0] = 0;return;}if (flag == 1) {				for (int i=1; i<=a[0]; i++) {if (a[i] < b[i]) {			 a[i+1]--;			a[i] += 10;}a[i] -= b[i];}while (a[0]>0 && a[a[0]]==0) {a[0]--;					} return; }				 
}  // 高精减法void chugao(int a[], int b[], int c[]) {int tmp[50005];c[0] = a[0] - b[0] + 1;for (int i=c[0]; i>0; i--) {memset(tmp, 0, sizeof(tmp));	numcpy(b, tmp, i);// 清零while (compare(a, tmp) >= 0) {c[i]++;jian(a, tmp);	// 用减法模拟		} }while (c[0] > 0 && c[c[0]] == 0) {c[0]--;}return;
}int main() {memset(a, 0, sizeof(a));memset(b, 0, sizeof(b));memset(c, 0, sizeof(c));init(a);init(b);chugao(a,b,c);print(c);	return 0;
}

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

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

相关文章

java - 七大比较排序 - 详解

前言 本篇介绍了七大比较排序&#xff0c;直接插入排序&#xff0c;希尔排序&#xff0c;冒泡排序&#xff0c;堆排序&#xff0c;选择排序&#xff0c;快速排序&#xff0c;归并排序&#xff0c;一些简单思想代码实现&#xff0c;如有错误&#xff0c;请在评论区指正&#xf…

深入探讨 Presto 中的缓存

【squids.cn】 全网zui低价RDS&#xff0c;免费的迁移工具DBMotion、数据库备份工具DBTwin、SQL开发工具等 Presto是一种流行的开源分布式SQL引擎&#xff0c;使组织能够在多个数据源上大规模运行交互式分析查询。缓存是一种典型的提高 Presto 查询性能的优化技术。它为 Prest…

kr 第三阶段(三)调试器

调试框架 特点&#xff1a;事件驱动&#xff0c;事件响应。 Win32 程序是消息驱动响应的基址&#xff0c;而在调试器则是事件驱动响应&#xff0c;有事件则处理&#xff0c;无事件则去做别的事。 事件&#xff1a;整个调试框架是建立在异常的基础之上的基本单位。响应&#xf…

基于ssm的互联网废品回收/基于web的废品资源利用系统

摘 要 本毕业设计的内容是设计并且实现一个基于SSM框架的互联网废品回收。它是在Windows下&#xff0c;以MYSQL为数据库开发平台&#xff0c;Tomcat网络信息服务作为应用服务器。互联网废品回收的功能已基本实现&#xff0c;主要包括用户、回收员、物品分类、回收物品、用户下单…

【技能树笔记】网络篇——练习题解析(四)

目录 前言 一、传输层的作用 1.1 传输层的作用 1.2 传输层的PDU 二、端口号的分类、作用 2.1 传输层的PDU 三、TCP协议的特点及应用 3.1 传输层的PDU 3.2 TCP协议连接的建立 四、UDP协议的特点及应用 4.1 UDP协议的特点 总结 前言 本篇文章给出了CSDN网络技能树中…

操作系统内存管理相关

1. 虚拟内存 1.1 什么是虚拟内存 虚拟内存是计算机系统内存管理的一种技术&#xff0c;我们可以手动设置自己电脑的虚拟内存。不要单纯认为虚拟内存只是“使用硬盘空间来扩展内存“的技术。虚拟内存的重要意义是它定义了一个连续的虚拟地址空间&#xff0c;并且 把内存扩展到硬…

2023年中国体育赛事行业现状及趋势分析:体育与科技逐步融合,推动产业高质量发展[图]

体育赛事运营是指组织体育赛事或获取赛事版权&#xff0c;并进行赛事推广营销、运营管理等一系列商业运作的运营活动。体育赛事运营相关业务主要包括赛事运营与营销、赛事版权运营两个部分。 体育赛事运营行业分类 资料来源&#xff1a;共研产业咨询&#xff08;共研网&#x…

Java 实现遍历一个文件夹,文件夹有100万数据,获取到修改时间在2天之内的数据

目录 1 需求2 实现1&#xff08;第一种方法&#xff09;2 实现2 &#xff08;推荐使用这个&#xff0c;快&#xff09;3 实现3&#xff08;推荐&#xff09; 1 需求 现在有一个文件夹&#xff0c;里面会一直存数据&#xff0c;动态的存数据&#xff0c;之后可能会达到100万&am…

JVM-满老师

JVM 前言程序计数器&#xff0c;栈&#xff0c;虚拟机栈&#xff1a;本地方法栈&#xff1a;堆&#xff0c;方法区&#xff1a;堆内存溢出方法区运行时常量池 前言 JVM 可以理解的代码就叫做字节码&#xff08;即扩展名为 .class 的文件&#xff09;&#xff0c;它不面向任何特…

SLAM从入门到精通(python开发)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 在ROS下面&#xff0c;开发的方法很多&#xff0c;可以是c&#xff0c;可以是python。大部分接口操作类的应用&#xff0c;其实都可以用python来开…

Day 04 python学习笔记

Python数据容器 元组 元组的声明 变量名称&#xff08;元素1&#xff0c;元素2&#xff0c;元素3&#xff0c;元素4…….&#xff09; &#xff08;元素类型可以不同&#xff09; eg: tuple_01 ("hello", 1, 2,-20,[11,22,33]) print(type(tuple_01))结果&#x…

<C++> 异常

C语言传统的处理错误的方式 传统的错误处理机制&#xff1a; 终止程序&#xff0c;如assert&#xff0c;缺陷&#xff1a;用户难以接受。如发生内存错误&#xff0c;除0错误时就会终止程序。返回错误码&#xff0c;缺陷&#xff1a;需要程序员自己去查找对应的错误。如系统的…

c++中的动态内存管理

目录 1.内存分布 2.c语言动态内存管理 3.c动态内存管理 4.operator new 与operator delete 函数 5.定位new 6.malloc/free 与 new/delete 的区别 1.内存分布 首先我们需要了解一下数据在内存中的分布&#xff0c;请看以下代码&#xff1a; int globalVar 1; static in…

2023年全球接口IP市场发展趋势分析:市占率第二IP品类,受大数据及计算需求推动高速增长[图]

接口IP是基于标准接口协议&#xff0c;实现芯片与内外部设备进行通信、传输数据的电路模块&#xff0c;分为有线接口IP与无线接口IP&#xff0c;主要用于数字信号处理和嵌入式系统中的接口设计。 接口IP分类 资料来源&#xff1a;共研产业咨询&#xff08;共研网&#xff09; …

计算机视觉——飞桨深度学习实战-深度学习网络模型

深度学习网络模型的整体架构主要数据集、模型组网以及学习优化过程三部分&#xff0c;本章主要围绕着深度学习网络模型的算法架构、常见模型展开了详细介绍&#xff0c;从经典的深度学习网络模型以CNN、RNN为代表&#xff0c;到为了解决显存不足、实时性不够等问题的轻量化网络…

【LeetCode热题100】--226.翻转二叉树

226.翻转二叉树 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.val val; }* TreeNode(int val, TreeNode left, TreeNode right) {* …

TouchGFX之后端通信

在大多数应用中&#xff0c;UI需以某种方式连接到系统的其余部分&#xff0c;并发送和接收数据。 它可能会与硬件外设&#xff08;传感器数据、模数转换和串行通信等&#xff09;或其他软件模块进行交互通讯。 Model类​ 所有TouchGFX应用都有Model类&#xff0c;Model类除了存…

苹果ios系统ipa文件企业签名是什么?优势是什么?什么场合需要应用到?

企业签名是苹果开发者计划中的一种签名类型&#xff0c;允许企业开发者签署和分发企业内部使用的应用程序&#xff0c;而无需通过App Store进行公开发布。通过企业签名&#xff0c;企业可以在内部部署自己的应用程序&#xff0c;以满足特定的业务需求。 企业签名能够做到以下…

搭建自己的搜索引擎之五

一、前言 接上文 搭建自己的搜索引擎之四&#xff0c;下面继续介绍茴香豆茴字的另外两种写法。 二、Jest Jest是ES的Java Http Rest客户端&#xff0c;它主要是为了弥补以前ES自有API缺少HttpRest接口客户端的不足&#xff0c;但因为现在ES官方已经提供了RestClient ,该项目已…

数据结构和算法

数据结构&#xff1a; 线性结构&#xff1a; 顺序存储方式&#xff0c;顺序表 常见的顺序存储结构有&#xff1a;数组、队列、链表、栈 链式存储方式&#xff0c;链表 非线性结构&#xff1a; 常见的非线性结构有&#xff1a;二维数组、多维数组、广义表、树结构、图结构 实…