【高精度】-DLUTOJ-1176-大数乘法

2024-09-03 22:18

本文主要是介绍【高精度】-DLUTOJ-1176-大数乘法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:http://acm.dlut.edu.cn/problem.php?id=1176

题目描述:赤裸的大数乘法

解题思路:

突然想到自己没写过高精度乘法,就回咱们自己OJ上找出了这道题,赤裸的高精度乘法而已,没想到依然觉得不好写,准确说来是我从小到大算乘法的习惯使我产生了错觉:“ 想写大数乘法就得先写一个大数加法出来 ”。喂!我短路了半天才想明白,int 数组里可以存个两位数啊,再进位不就好了。(#`O′) 。。然后又照刘汝佳说的把数组反过来写,果然方便了一些。

AC代码:

#include <iostream>
#include <cstring>
#include <cstdio>using namespace std;char a[300],b[300];
int ra[300],rb[300],cal[300],temp[300],ans[300],la,lb,point;void dancheng(int a[],int b)
{int i,j,k,t,c=0;for(i=0;i<300;i++){t=a[i]*b+c;c=t/10;temp[i]=t%10;}for(k=250;k>=0;k--)if(temp[k])break;for(i=point,j=0;j<=k;i++,j++){ans[i]+=temp[j];}point++;
}void cheng(char a[],char b[])
{int i,j;for(i=la-1,j=0;i>=0;j++,i--)ra[j]=a[i]-'0';for(i=lb-1,j=0;i>=0;j++,i--)rb[j]=b[i]-'0';for(i=0;i<lb;i++){memset(temp,0,sizeof(temp));dancheng(ra,rb[i]);}
}int main()
{int T,i,t,c=0;cin>>T;while(T--){memset(a,0,sizeof(a));memset(b,0,sizeof(b));memset(ans,0,sizeof(ans));memset(ra,0,sizeof(ra));memset(rb,0,sizeof(rb));point=0;cin>>a>>b;if(strlen(a)>strlen(b)){la=strlen(a);lb=strlen(b);cheng(a,b);}else{la=strlen(b);lb=strlen(a);cheng(b,a);}for(i=0;i<250;i++){t=ans[i]+c;c=t/10;ans[i]=t%10;}for(i=250;i>=0;i--)if(ans[i])break;if(i==-1)cout<<0;elsefor(;i>=0;i--)cout<<ans[i];cout<<endl;}return 0;
}

AC截图:



这篇关于【高精度】-DLUTOJ-1176-大数乘法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

hdu 6198 dfs枚举找规律+矩阵乘法

number number number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem Description We define a sequence  F : ⋅   F0=0,F1=1 ; ⋅   Fn=Fn

Java验证辛钦大数定理

本实验通过程序模拟采集大量的样本数据来验证辛钦大数定理。   实验环境: 本实验采用Java语言编程,开发环境为Eclipse,图像生成使用JFreeChart类。   一,验证辛钦大数定理 由辛钦大数定理描述为: 辛钦大数定理(弱大数定理)  设随机变量序列 X1, X2, … 相互独立,服从同一分布,具有数学期望E(Xi) = μ, i = 1, 2, …, 则对于任意正数ε ,

高精度计算(代码加解析,洛谷p1601,p1303)除法待更新

目录 高精度加法 高精度减法 高精度乘法 高精度加法 我们知道在c++语言中任何数据类型都有一定的表示范围。当两个被加数很大时,正常加法不能得到精确解。在小学,我们做加法都采用竖式方法。那么我们也只需要按照加法进位的方式就能得到最终解。 8 5 6+ 2 5 5-------1 1 1 1 加法进位: c[i] = a[i] + b[i];if(c[i] >=

高精度打表-Factoring Large Numbers

求斐波那契数,不打表的话会超时,打表的话普通的高精度开不出来那么大的数组,不如一个int存8位,特殊处理一下,具体看代码 #include<stdio.h>#include<string.h>#define MAX_SIZE 5005#define LEN 150#define to 100000000/*一个int存8位*/int num[MAX_SIZE][LEN];void

高精度计算----减法运算(浮点型)

基于上一贴,修改减法运算适合于高精度浮点型计算。 因为减法比加法难度大一点,考虑的地方也要多一些,可能代码有欠缺,欢迎指出。 运算说明: 1、相减函数依旧没改变,包括上一贴的判断被减数与减数的大小函数也没变。 2、增加两个函数,取小数位数函数和结果处理(回归小数点)函数 3、与加法浮点高精度运算相比,这里改变较多的是结果处理函数,加法加完后,位数不减反增,而且最多增一位。减法会消失掉好多

高精度计算----减法运算

处理大数减法运算: 1、首先要判断被减数与减数哪个更大,再相应的带入减法函数去处理。具体的比较可以使用字符串的相关知识去比较。 2、相减要先对齐数组,依照减数的长度,执行相应的减法运算次数。 3、不需要借位相减的话,直接减去;需要的话,向前借一位,若前一位是0,则再前借(此时前一位的0变为10)。 测试程序效果如下:   以下代码包括相减函数,比较被减数减数函数,若有错误,请指出:

高精度加法,乘法,阶乘

#include <iostream>#include <map>#include <string>#include <algorithm>using namespace std;const int Max = 50000;string str1,str2;/***********乘法***********/void chenfa(){cin >> str1>>str2;int a

找第K大数(ACdream 1099)

瑶瑶的第K大 Time Limit: 4000/2000MS (Java/Others)  Memory Limit: 256000/128000KB (Java/Others) Submit  Statistic  Next Problem Problem Description 一天,萌萌的妹子--瑶瑶(tsyao)很无聊,就来找你玩。可是你们都不知道玩什么。。。