就一个简单的大数计算

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

相关文章

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

Java计算经纬度距离的示例代码

《Java计算经纬度距离的示例代码》在Java中计算两个经纬度之间的距离,可以使用多种方法(代码示例均返回米为单位),文中整理了常用的5种方法,感兴趣的小伙伴可以了解一下... 目录1. Haversine公式(中等精度,推荐通用场景)2. 球面余弦定理(简单但精度较低)3. Vincenty公式(高精度,

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则

如何使用Python实现一个简单的window任务管理器

《如何使用Python实现一个简单的window任务管理器》这篇文章主要为大家详细介绍了如何使用Python实现一个简单的window任务管理器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 任务管理器效果图完整代码import tkinter as tkfrom tkinter i