蓝桥杯练习系统(算法训练)ALGO-977 P0805大数乘法

资源限制

内存限制:256.0MB   C/C++时间限制:1.0s   Java时间限制:3.0s   Python时间限制:5.0s

  当两个比较大的整数相乘时,可能会出现数据溢出的情形。为避免溢出,可以采用字符串的方法来实现两个大数之间的乘法。具体来说,首先以字符串的形式输入两个整数,每个整数的长度不会超过10位,然后把它们相乘的结果存储在另一个字符串当中(长度不会超过20位),最后把这个字符串打印出来。例如,假设用户输入为:62773417和12345678,则输出结果为:774980393241726.
  编写函数 void Multiply(char* s1, char* s2, char* result); 实现大数乘法(只考虑正整数),其中result = s1 * s2.
  编写main函数测试该函数的正确性.

输入:
  62773417 12345678

输出:
  774980393241726

#include<iostream>
#include<string>
using namespace std;
int a[15],b[15],c[25];
void Multiply(string s1,string s2){
	for(int i=0;i<s1.length();i++){
		a[s1.length()-i]=s1[i]-'0';//逆序存储 
	} 
	for(int i=0;i<s2.length();i++){
		b[s2.length()-i]=s2[i]-'0';
	}
	for(int i=1;i<=s1.length();i++){
		for(int j=1;j<=s2.length();j++){
			c[i+j-1]+=a[i]*b[j];
			c[i+j]+=c[i+j-1]/10;//进位 
			c[i+j-1]%=10;//当前位置的数值,大于等于10需要进位 
		}
	} 
	int lc=s1.length()+s2.length();
	while(lc>0&&c[lc]==0) lc--;
	for(int i=lc;i>=1;i--){
		printf("%d",c[i]);//逆序输出 
	}
} 
int main(){
	string s1,s2;
	cin>>s1>>s2;
	Multiply(s1,s2);
	return 0;
}

思路:高精度乘法。由于计算乘法时,先计算低位,因此a[0]存储大数的低位。

例如:计算12345678×9,显然是被乘数中的最低位8和乘数9相乘。为了方便操作和对齐,将大数都逆序存储。即a[]:8 7 6 5 4 3 2 1。

 

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-13 09:30:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-13 09:30:03       101 阅读
  3. 在Django里面运行非项目文件

    2024-03-13 09:30:03       82 阅读
  4. Python语言-面向对象

    2024-03-13 09:30:03       91 阅读

热门阅读

  1. php运行报错: Class ‘SimpleXMLElement‘ not found in

    2024-03-13 09:30:03       46 阅读
  2. linux 命令之tar命令

    2024-03-13 09:30:03       41 阅读
  3. SeaTunnel-web in K8S

    2024-03-13 09:30:03       41 阅读
  4. 控件交互的优劣势--自动窗帘系统

    2024-03-13 09:30:03       40 阅读
  5. 【ARM linux mqtt协议连接服务器】

    2024-03-13 09:30:03       44 阅读
  6. 华纳云bgp线路服务器的优点和缺点

    2024-03-13 09:30:03       43 阅读
  7. VSCode调试C++项目时无法显示长字符串的所有内容

    2024-03-13 09:30:03       38 阅读
  8. 借助知识图谱和Llama-Index实现基于大模型的RAG

    2024-03-13 09:30:03       36 阅读
  9. 简单使用Xmind

    2024-03-13 09:30:03       45 阅读
  10. 什么是浅拷贝和深拷贝

    2024-03-13 09:30:03       46 阅读