算法模板 - C++ 高精度运算
C++算法板子
高精度
高精度推荐用python来写,python有大整数,这里写的是关于C++的高精度运算模板
1、高精 * 低精
#include <iostream>
#include <vector>
using namespace std;
vector<int> mul ( vector<int> A, int b )
{
vector<int> C; // 结果按位存到 C 中
int t = 0; // 存放进位的数
for ( int i = 0; i < A.size() || t; i++ ) // i 代表 现在在第几位上
{
if ( i < A.size() ) t += A[i] * b;
C.push_back ( t % 10 );
t /= 10;
}
while ( C.size() > 1 && C.back() == 0 ) C.pop_back(); // 消除最高位上多余的0
return C;
}
int main ( void )
{
// 计算 C = A * b;
string a; // eg. input >> "123456" -> a;
int b;
vector<int> A, C; // A 将存储 "654321";
cin >> a >> b;
for ( int i = a.size() - 1; i >= 0; i-- ) A.push_back( a[i] - '0' );
C = mul ( A, b );
for ( int i = C.size() - 1; i >= 0; i-- ) cout << C[i];
return 0;
}
while ( C.size() > 1 && C.back() == 0 ) C.pop_back(); // 消除最高位上多余的0
这个是为了防止以下情况出现
2、高精 + 高精
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
vector<int> add ( vector<int> A, vector<int> B )
{
vector<int> C;
int t = 0;
for ( int i = 0; i < A.size() || i < B.size(); i++ )
{
if ( i < A.size() ) t += A[i];
if ( i < B.size() ) t += B[i];
C.push_back ( t % 10 );
t /= 10;
}
if ( t ) C.push_back ( 1 );
return C;
}
int main ( void )
{
string a, b;
vector<int> A, B, C;
cin >> a >> b;
for ( int i = a.size() - 1; i >= 0; i-- )
A.push_back ( a[i] - '0' );
for ( int i = b.size() - 1; i >= 0; i-- )
B.push_back ( b[i] - '0' );
C = add ( A, B );
for ( int i = C.size() - 1; i >= 0; i-- )
printf ( "%d", C[i] );
return 0;
}
3、高精 - 高精
#include <iostream>
#include <vector>
using namespace std;
bool cmp ( string a, string b )
{
if ( a.size() > b.size() ) return true;
else if ( a.size() < b.size() ) return false;
else if ( a >= b ) return true; // 长度相同时 按字典序大小比较
else return false;
}
vector<int> sub ( vector<int> A, vector<int> B )
{
vector<int> C;
int t = 0;
for ( int i = 0; i < A.size(); i++ )
{
t = A[i] - t;
if ( i < B.size() ) t -= B[i];
C.push_back ( (t + 10) % 10 );
if ( t < 0 ) t = 1;
else t = 0;
}
while ( C.size() > 1 && C.back() == 0 ) C.pop_back();
return C;
}
int main ( void )
{
string a, b; // 输入 “123456”
vector<int> A, B, C; // 转换为“654321”存放到
cin >> a >> b;
for ( int i = a.size() - 1; i >= 0; i-- ) A.push_back ( a[i] - '0' ); // 倒序存储 “654321”
for ( int i = b.size() - 1; i >= 0; i-- ) B.push_back ( b[i] - '0' );
if ( cmp ( a, b ) )
{
C = sub ( A, B );
} else {
cout << "-"; // A < B 时,先输出负号
C = sub ( B, A );
}
for ( int i = C.size() - 1; i >= 0; i-- ) cout << C[i];
return 0;
}
4、高精 / 低精 ,余 低精
计算非负整数相除,分母不为零
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
vector<int> div ( vector<int> A, int b, int &t ) // 注意 t 为 “引用”
{
vector<int> C;
t = 0;
for ( int i = A.size() - 1; i >= 0; i-- ) // 注意这里是正序修改(在倒序的基础上倒序)
{
t = t * 10 + A[i];
C.push_back ( t / b );
t %= b;
}
reverse ( C.begin(), C.end() ); // 倒序修改后导致答案是正序的 将其反转为倒序
while ( C.size() > 1 && C.back() == 0 ) C.pop_back(); // 后面的步骤都一样了
return C;
}
int main ( void )
{
string a; // 需要输入正序 a 然后倒序存入 A
int b;
vector<int> A, C;
cin >> a >> b;
for ( int i = a.size() - 1; i >= 0; i-- ) A.push_back ( a[i] - '0' );
int t = 0; // t 存放余数;
C = div ( A, b, t ); // 高精 A * 低精 b 余低精 t
for ( int i = C.size() - 1; i >= 0; i-- ) cout << C[i]; // 倒序打印输出答案 ( 因是倒序存储 )
cout << endl << t;
}
算法模板 - C++ 高精度运算的更多相关文章
- 算法模板学习专栏之总览(会慢慢陆续更新ing)
博主欢迎转载,但请给出本文链接,我尊重你,你尊重我,谢谢~http://www.cnblogs.com/chenxiwenruo/p/7495310.html特别不喜欢那些随便转载别人的原创文章又不给 ...
- 让ecshop模板支持php运算
让ecshop模板支持php运算在 cls_template.php 底部加入函数: /** * 处理if标签 * * @access public * @param string $tag_args ...
- 匈牙利 算法&模板
匈牙利 算法 一. 算法简介 匈牙利算法是由匈牙利数学家Edmonds于1965年提出.该算法的核心就是寻找增广路径,它是一种用增广路径求二分图最大匹配的算法. 二分图的定义: 设G=(V,E)是一个 ...
- Tarjan 算法&模板
Tarjan 算法 一.算法简介 Tarjan 算法一种由Robert Tarjan提出的求解有向图强连通分量的算法,它能做到线性时间的复杂度. 我们定义: 如果两个顶点可以相互通达,则称两个顶点强连 ...
- hdu 2255 奔小康赚大钱--KM算法模板
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2255 题意:有N个人跟N个房子,每个人跟房子都有一定的距离,现在要让这N个人全部回到N个房子里面去,要 ...
- POJ 1273 Drainage Ditches(网络流dinic算法模板)
POJ 1273给出M条边,N个点,求源点1到汇点N的最大流量. 本文主要就是附上dinic的模板,供以后参考. #include <iostream> #include <stdi ...
- poj 1274 The Perfect Stall【匈牙利算法模板题】
The Perfect Stall Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 20874 Accepted: 942 ...
- 高精度运算专题3-乘法运算(The multiplication operation)
这个专题呢,我就来讲讲高精度的乘法,下面是三个计算乘法的函数,第一个函数是char类型的,要对字符串进行数字转换,而第二个是两个int类型的数组,不用转换成数字,第三个则更为优化,用a数组-b数组放回 ...
- [code]高精度运算
数组存储整数,模拟手算进行四则运算 阶乘精确值 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 #includ ...
随机推荐
- Hbase备份以及清表脚本
脚本主要是方便自己工作使用,服务器环境中配置了hbase相关环境变量 1.hbase备份脚本 #!/bin/bash tableList=("table1" "table ...
- 面试 07-安全问题:CSRF和XSS
07-安全问题:CSRF和XSS #前言 面试中的安全问题,明确来说,就两个方面: CSRF:基本概念.攻击方式.防御措施 XSS:基本概念.攻击方式.防御措施 这两个问题,一般不会问太难. 有人问: ...
- react第十二单元(react路由-使用react-router-dom-认识相关的组件以及组件属性)
第十二单元(react路由-使用react-router-dom-认识相关的组件以及组件属性) #课程目标 理解路由的原理及应运 理解react-router-dom以及内置的一些组件 合理应用内置组 ...
- 【软件测试 Python自动化】全网最全大厂面试题,看完以后你就是面试官!
前言 为了让大家更好的理解和学习投入到Python自动化来找到一份好的资料也是学习过程中,非常重要的一个点.你的检索能力越强,你就会越容易找到最合适你的资料. 有需要的小伙伴可以复制群号 313782 ...
- 多任务-python实现-Thread的基本使用(2.1.1)
@ 目录 1.多任务的概念 2.线程 1.多任务的概念 "多任务工作"指的是当前很普遍的工作状态,一个人同时处理多件事情,比如以下这个常见的画面:写一会报告,刷一下网页,查一下资料 ...
- 程序猿的浪漫:用python画动态爱心
初级画心 学Python,感觉你们的都好复杂,那我来个简单的,我是直接把心形看作是一个正方形+两个半圆:
- Python之word文档替换字符串(也可以用于短模板套用)
Python之word文档替换字符串(也可以用于短模板套用),代码如下: 1 ''' 2 #word模板套用1:创建模板,适合比较短的文档 3 ''' 4 5 #导入所需库 6 from docx i ...
- redis scan 命令指南
redis scan 命令指南 1. 模糊查询键值 redis 中模糊查询key有 keys,scan等,一下是一些具体用法. -- 命令用法:keys [pattern] keys name* -- ...
- ES标签搜索并解决评分排序问题
一.概述 需求: 最近在做一个新闻项目,有这样一个需求,如下: 用户根据视频内容手动创建标签,标签个数不限 在视频详情页提供根据标签推荐视频功能,即按本视频的标签进行搜索,标签匹配多的排在前面,匹配少 ...
- grpc系列- protobuf详解
Protocol Buffers 是一种与语言.平台无关,可扩展的序列化结构化数据的方法,常用于通信协议,数据存储等等.相较于 JSON.XML,它更小.更快.更简单,因此也更受开发人员的青眯. 基本 ...