就一个简单的大数计算

2024-09-01 05:32
文章标签 简单 计算 大数

本文主要是介绍就一个简单的大数计算,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

也只是刚刚写出了加法,用的是1 000 000 000进制,不过发现对于加法还不如用最基本的方法方便。用1 000 000 000进制的方便也就在于处理乘法和除法了。计算机做乘除运算还是比较耗时的。

#include <random>
#include <iostream>
#include <fstream>
#include <string>
#include <vector>
#include <utility>
using namespace std;
const int MaxNum=1000000000; //进制
class BigNumCalcu{
public:const static int N=9;BigNumCalcu():num_1(""),result(""),numSize_1(0),numSize_2(0){  //initnum_2="";fopen.open("num.txt");}string patchZero(int M); //补0void getInput();   //读取数据void SplitNum(); void Sum();      //加法string Sub();      //减法void Multi();    //乘法string Div();      //除法void randomData();
private:fstream fopen;vector<int> BitNum_1,BitNum_2;string num_1,num_2,result;unsigned int numSize_1;unsigned int numSize_2;
};void BigNumCalcu::getInput(){for(int i=0;i!=5;++i){result="";BitNum_1.clear();BitNum_2.clear();fopen>>num_1>>num_2;cout<<"num_1: "<<num_1<<"  num_2: "<<num_2<<endl;SplitNum();Sum();}
}
void BigNumCalcu::SplitNum(){numSize_1=(num_1.size()%9==0) ? num_1.size()/9 : num_1.size()/9+1;numSize_2=(num_2.size()%9==0) ? num_2.size()/9 : num_2.size()/9+1;//splitif(numSize_1==num_1.size()/9)for(int index=1;index<=numSize_1;++index)BitNum_1.push_back(std::stoi(num_1.substr(num_1.size()-index*BigNumCalcu::N,9)));elsefor(int index=1;index<=numSize_1;++index){if(index==numSize_1)BitNum_1.push_back(std::stoi(num_1.substr(0,num_1.size()-(index-1)*BigNumCalcu::N)));elseBitNum_1.push_back(std::stoi(num_1.substr(num_1.size()-index*BigNumCalcu::N,9)));        }if(numSize_2==num_2.size()/9)for(int index=1;index<=numSize_2;++index)BitNum_2.push_back(std::stoi(num_2.substr(num_2.size()-index*BigNumCalcu::N,9)));elsefor(int index=1;index<=numSize_2;++index){if(index==numSize_2)BitNum_2.push_back(std::stoi(num_2.substr(0,num_2.size()-(index-1)*BigNumCalcu::N)));elseBitNum_2.push_back(std::stoi(num_2.substr(num_2.size()-index*BigNumCalcu::N,9)));        }
}string BigNumCalcu::patchZero(int M){auto it=std::to_string(M).size();string temp=std::to_string(M);if(it<BigNumCalcu::N){for(;it<BigNumCalcu::N;it++)temp="0"+temp;return result=temp+result;}elsereturn result=std::to_string(M);
}void BigNumCalcu::Sum(){int min=std::min(numSize_1,numSize_2);int index=0;  //进位int sum=0;//如果兩個數字具有相同的位数//如果两个数字位数不一样if(min==numSize_1)for(int count=min;count<numSize_2;++count)if((sum=BitNum_2[count]+index)>=MaxNum){index=1;result=patchZero(sum-MaxNum);}else{index=0;result=patchZero(sum);}elsefor(int count=min;count<numSize_1;++count)if((sum=BitNum_1[count]+index)>=MaxNum){index=1;result=patchZero(sum-MaxNum);}else{index=0;result=patchZero(sum);}//如果最高位也需要进位if(index==1)result="1"+result;cout<<result<<endl;
}int main(int argc,char **argv){BigNumCalcu Calc;Calc.getInput();return 0;
}

下面是一个python测试。因为python已经自带大整数计算了

__author__='MarkLiang'
#coding=utf-8fopen=open('num.txt','r')
for num1 in fopen:num2=fopen.readline();print("result: ",int(num1)+int(num2))fopen.close()

至于乘法和除法,我有空在写吧。

这篇关于就一个简单的大数计算的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 10130 简单背包

题意: 背包和 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <queue>#include <map>

uva 1342 欧拉定理(计算几何模板)

题意: 给几个点,把这几个点用直线连起来,求这些直线把平面分成了几个。 解析: 欧拉定理: 顶点数 + 面数 - 边数= 2。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#inc

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

uva 10069 DP + 大数加法

代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <queue>#include <map>#include <cl

XTU 1237 计算几何

题面: Magic Triangle Problem Description: Huangriq is a respectful acmer in ACM team of XTU because he brought the best place in regional contest in history of XTU. Huangriq works in a big compa