A+B and A*B problem 大数相加 相乘 模拟
A+B and A*B problem 大数相加 相乘 模拟
题意
给你两个数a和b,这两个数很大,然后输出这两个数相加的和,相乘的积。
解题思路
模拟,但是还是搜了搜代码实现,发现这个大佬写的是真的简洁高效。
下面第一个代码转自博客(修改了一些) 》》》https://blog.csdn.net/hacker00011000/article/details/51298294
第二个代码是CZH同学的代码,代码更是简单易懂!
别的一些思路
大数相加相乘 https://blog.csdn.net/weixin_41162823/article/details/80044079
高精度快速幂 https://www.luogu.org/problemnew/solution/P1045
代码实现
#include <iostream>
#include <sstream>
#include <algorithm>
#include <cstring>
#include <string>
using namespace std;
//C++大数相加
string BigNumAdd(const string& strNum1, const string& strNum2)
{
string strSum;
int len1 = strNum1.size()-1;
int len2 = strNum2.size()-1;
int bit = 0; //保存进位
//从结尾开始每位相加
while (len1>=0 && len2>=0)
{
//求每位的和(要把进位也加上)
int tmpSum = strNum1[len1]-'0' + strNum2[len2]-'0' + bit;
//保存进结果
strSum += tmpSum % 10 + '0';
//求进位
bit = tmpSum / 10;
--len1;
--len2;
}
//两个整数长度不相等(肯定有一个已经加完了,不需要再额外加if来判断,因为while就可以判断)
while (len1 >= 0)
{
//和上个while循环一样
int tmpSum = strNum1[len1]-'0' + bit;
strSum += tmpSum % 10 + '0';
bit = tmpSum / 10;
--len1;
}
while (len2 >= 0)
{
//和上个while循环一样
int tmpSum = strNum2[len2]-'0' + bit;
strSum += tmpSum % 10 + '0';
bit = tmpSum / 10;
--len2;
}
//最高位有进位
if (bit != 0)
strSum += bit + '0';
//反转
reverse(strSum.begin(), strSum.end());
return strSum;
}
//C++大数相乘
string BigNumMultiply(const string& strNum1, const string& strNum2)
{
string strMultiply;
//两数相乘最大有m+n位
int bit = 0;
int len1 = strNum1.size()-1;
int len2 = strNum2.size()-1;
//计算每一位
for (int i=0; i<len1+len2+2; ++i)
{
//计算结果的第i位(权值肯定为i,第1位也就是个位权值为0(pow(10, 0)))
//等于乘数的第(i~0)位分别与被乘数的第(0~i)位相乘,因为这样每位相乘之后权值仍为i
//然后相加再加上前一位的进位,就是结果的第i位
//然后%10得出第i位,/10得到进位
int tmp = 0;
for (int j=i; j>=0; --j)
{
//如果下标超出字符串的范围 j为num1的下标, i-j为num2的下标,然后两数相乘
if (j>len1 || (i-j)>len2)
continue;
//还要注意字符串数字的最高位在字符串的最低位所以得用len减去
tmp += (strNum1[len1-j]-'0') * (strNum2[len2-(i-j)]-'0');
}
//加上进位
tmp += bit;
//为了防止最后一位是0,但是却加上了
if (tmp == 0 && i == len1+len2+1)
break;
//求余得到结果的第i位
strMultiply += tmp % 10 + '0';
//计算新的进位
bit = tmp / 10;
}
//判断结果的最后一个字符如果是0的话说明可以删去
//if (strMultiply[strMultiply.size()-1] == '0')
// strMultiply[strMultiply.size()-1] = '\0';
//反转
reverse(strMultiply.begin(), strMultiply.end());
return strMultiply;
}
int main()
{
string str1;
string str2;
cin >> str1 >> str2;
//相加和相乘
cout << BigNumAdd(str1, str2) << endl;
cout << BigNumMultiply(str1, str2) << endl;
return 0;
}
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn = 10010;
int a[maxn],b[maxn];
int ans[maxn];
int ans2[maxn];
int main()
{
string s1,s2;
cin>>s1>>s2;
int len1 = s1.length();
int len2 = s2.length();
int lenans = 0, lenans2 = 0;
int n = 0;
for(int i=0;i<len1;i++)
a[i] = s1[i]-'0';
reverse(a, a+len1);
for(int i=0;i<len2;i++)
{
b[i] = s2[i]-'0';
n = n*10 + s2[i]-'0';
}
reverse(b, b+len2);
for(int i=0,up=0;i<maxn;i++)
{
ans[i] = a[i]+b[i]+up;
up = ans[i]/10;
ans[i] %= 10;
}
for(int i=maxn-1;i!=-1;i--)
{
if(ans[i])
{
lenans = i;
break;
}
}
for(int i=lenans;i!=-1;i--)
cout<<ans[i];
cout<<endl;
for(int i=0;i<maxn;i++)
{
ans2[i] = a[i]*n+ans2[i];
ans2[i+1] = ans2[i]/10;
ans2[i] %= 10;
}
for(int i=maxn-1;i!=-1;i--)
{
if(ans2[i])
{
lenans2 = i;
break;
}
}
for(int i=lenans2;i!=-1;i--)
cout<<ans2[i];
cout<<endl;
return 0;
}
#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
const int maxn=100;
char a[maxn], b[maxn];
int len, len1, len2;
int anum[maxn], bnum[maxn], sum[maxn];
int main()
{
cin>>a>>b;
len1=strlen(a);
len2=strlen(b);
len=max(len1, len2);
for(int i=len1-1, j=0; i>=0; i--, j++)
anum[j]=a[i]-'0';
for(int i=len2-1, j=0; i>=0; i--, j++)
bnum[j]=b[i]-'0';
for(int i=0; i<=len; i++)
{
sum[i]+=anum[i]+bnum[i];
if(sum[i]>9)
{
sum[i+1]+=sum[i]/10;
sum[i]%=10;
}
}
int begin=0;
for(int i=len; i>=0; i--)
{
if(sum[i]!=0)
{
begin=i;
break;
}
}
for(int i=begin; i>=0; i--)
cout<<sum[i];
cout<<endl;
memset(sum, 0, sizeof(sum));
for(int i=0; i<len1; i++)
{
for(int j=0; j<len2; j++)
sum[i+j]+=anum[i]*bnum[j];
}
for(int i=0; i<=len1+len2; i++)
{
if(sum[i]>9)
{
sum[i+1]+=sum[i]/10;
sum[i]%=10;
}
}
begin=0;
for(int i=len1+len2; i>=0; i--)
if(sum[i]!=0)
{
begin=i;
break;
}
for(int i=begin; i>=0; i--)
cout<<sum[i];
cout<<endl;
return 0;
}
A+B and A*B problem 大数相加 相乘 模拟的更多相关文章
- HDU-1002.大数相加(字符串模拟)
本题大意:给出两个1000位以内的大数a 和b,让你计算a + b的值. 本题思路:字符串模拟就能过,会Java的大佬应该不会点进来...... 参考代码: #include <cstdio&g ...
- 杭电ACM(1002) -- A + B Problem II 大数相加 -提交通过
杭电ACM(1002)大数相加 A + B Problem II Problem DescriptionI have a very simple problem for you. Given two ...
- hdu acm-1047 Integer Inquiry(大数相加)
Integer Inquiry Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)T ...
- hdu1002大数相加
A + B Problem II Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- HDU 1250 Hat's Fibonacci(大数相加)
传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1250 Hat's Fibonacci Time Limit: 2000/1000 MS (Java/Ot ...
- HDU 1297 Children’s Queue (递推、大数相加)
Children’s Queue Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- 用字符串模拟两个大数相加——java实现
问题: 大数相加不能直接使用基本的int类型,因为int可以表示的整数有限,不能满足大数的要求.可以使用字符串来表示大数,模拟大数相加的过程. 思路: 1.反转两个字符串,便于从低位到高位相加和最高位 ...
- 随机数组&大数相加
随机生成10个数,填充一个数组,然后用消息框显示数组内容,接着计算数组元素的和,将结果也显示在消息框中 一, 设计思路: 先生成随机数数组,再将数组保存在一个字符串中,然后将数组各数字加和, ...
- java-两个大数相加
题目要求:用字符串模拟两个大数相加. 一.使用BigInteger类.BigDecimal类 public static void main(String[] args) { String a=&qu ...
随机推荐
- python 脚本制作
U盘拷贝 当U盘插入主机时 被系统识别挂载后 通过python代码自动的去读取U盘中的资料并且进行拷贝 寄存在U盘上的 把硬盘上的资料进行读取并移动到U盘里 有点像 繁殖性 传输性 破坏性 破坏系统或 ...
- Java AtomicInteger类的使用方法详解_java - JAVA
文章来源:嗨学网 敏而好学论坛www.piaodoo.com 欢迎大家相互学习 首先看两段代码,一段是Integer的,一段是AtomicInteger的,为以下: public class Samp ...
- 【转】Linux逻辑卷管理
一. 前言 LVM是逻辑卷管理(Logical Volume Manager)的简称,它是建立在物理存储设备之上的一个抽象层,允许你生成逻辑存储卷,与直接使用物理存储在管理上相比,提供了更好灵活性.L ...
- break continue exit return 的区别
[root@localhost day1]# cat ss.sh #!/bin/bash for ((i=0;i<5;i++)) do if [ $i -eq 3 ] then break #c ...
- PHP开发环境 PHP培训教程
PHP开发环境 兄弟连小编整理如下: Centos安装apache,mysql,php环境 yum -y install httpd php mysql mysql-server php- ...
- html caption标签 语法
html caption标签 语法 caption是什么标签? 作用:定义表格标题. 说明:caption 标签必须紧随 table 标签之后.您只能对每个表格定义一个标题.通常这个标题会被居中于表格 ...
- Maven Waring : GroupId is duplicate of parent groupId 和 Version is duplicate of parent version
问题描述: 新项目在创建的时候,因为用到了分模块的,所以导致子模块的pom文件,报了 如下警告: 解决办法: 直接 Window --> Preferences --> Maven -- ...
- luogu P1181 数列分段Section I x
P1181 数列分段Section I 题目描述 对于给定的一个长度为N的正整数数列A[i],现要将其分成连续的若干段,并且每段和不超过M(可以等于M),问最少能将其分成多少段使得满足要求. 输入输出 ...
- Python常用的库简单介绍一下
Python常用的库简单介绍一下fuzzywuzzy ,字符串模糊匹配. esmre ,正则表达式的加速器. colorama 主要用来给文本添加各种颜色,并且非常简单易用. Prettytable ...
- [BZOJ1195]:[HNOI2006]最短母串(AC自动机+BFS)
题目传送门 题目描述 给定n个字符串(S1,S2,…,Sn),要求找到一个最短的字符串T,使得这n个字符串(S1,S2,…,Sn)都是T的子串. 输入格式 第一行是一个正整数n,表示给定的字符串的个数 ...