【HIHOCODER 1420】 Bigint Multiplication
描述
Given 2 nonnegative integers a and b, calculate a × b.
输入
One line with 2 integers a and b separated by a single space.
0 ≤ a, b ≤ 10100.
输出
The value of a × b.
样例输入
100000000000000000000 100000000000000000000
样例输出
10000000000000000000000000000000000000000
注意很多0时只要输出一个
#include <bits/stdc++.h>
#define ll long long
#define inf 1000000000
#define PI acos(-1)
#define bug puts("here")
#define REP(i,x,n) for(int i=x;i<=n;i++)
#define DEP(i,n,x) for(int i=n;i>=x;i--)
#define mem(a,x) memset(a,x,sizeof(a))
using namespace std;
inline int read(){
int x=0,f=1;
char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-') f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
}
const int N=205;
class BigNumber{
public:
char a[N];
int tot;
BigNumber(char t[]){
tot=0;
DEP(i,strlen(t)-1,0) a[tot++]=t[i];
}
BigNumber(){tot=0;}
};
BigNumber Add (BigNumber an,BigNumber bn){
int mn=max(bn.tot,an.tot),sum,add=0;
BigNumber tmp;
REP(i,0,mn-1){
sum=0;
if(i<bn.tot) sum+=bn.a[i]-'0';
if(i<an.tot) sum+=an.a[i]-'0';
sum+=add;
add=sum/10;sum%=10;
tmp.a[i]=sum+'0';
}
tmp.tot=mn;
if(add!=0) tmp.a[tmp.tot++]=add+'0';
return tmp;
}
BigNumber s1 (int s,BigNumber bn){
int sum,add=0;
BigNumber tmp;
REP(i,0,bn.tot-1){
sum=s*(bn.a[i]-'0')+add;
add=sum/10;sum%=10;
tmp.a[i]=sum+'0';
}
tmp.tot=bn.tot;
if(add!=0) tmp.a[tmp.tot++]=add+'0';
return tmp;
}
BigNumber multi (BigNumber an,BigNumber bn){
BigNumber c1,t;
int sum,add;
REP(i,0,an.tot-1){
t=s1(an.a[i]-'0',bn);
if(i!=an.tot-1){
DEP(j,bn.tot-1,0) bn.a[j+1]=bn.a[j];
bn.a[0]='0';
bn.tot++;
}
c1=Add(c1,t);
}
return c1;
}
char t1[N],t2[N];
int main(){
// while(1)
{
cin>>t1>>t2;
BigNumber ans=multi(BigNumber(t1),BigNumber(t2));
bool flag=false;
REP(i,0,ans.tot-1) if(ans.a[i]!='0') {flag=true;break;}
if(!flag) {puts("0");return 0;}
DEP(i,ans.tot-1,0) printf("%c",ans.a[i]);
puts("");
}
return 0;
}
【HIHOCODER 1420】 Bigint Multiplication的更多相关文章
- 【hihocoder 1298】 数论五·欧拉函数
[题目链接]:http://hihocoder.com/problemset/problem/1298 [题意] [题解] 用欧拉筛法; 能够同时求出1..MAX当中的所有质数和所有数的欧拉函数的值; ...
- 【hihocoder 1297】数论四·扩展欧几里德
[题目链接]:http://hihocoder.com/problemset/problem/1297 [题意] [题解] 问题可以转化为数学问题 即(s1+v1*t)%m == (s2+v2*t)% ...
- 【hihocoder 1296】数论三·约瑟夫问题
[题目链接]:http://hihocoder.com/problemset/problem/1296 [题意] [题解] [Number Of WA] 0 [完整代码] #include <b ...
- 【hihocoder 1295】Eular质数筛法
[题目链接]:http://hihocoder.com/problemset/problem/1295 [题意] [题解] 可以在O(N)的复杂度内求出1..N里面的所有素数; 当然受空间限制,N可能 ...
- 【hihocoder 1287】 数论一·Miller-Rabin质数测试
[题目链接]:http://hihocoder.com/problemset/problem/1287 [题意] [题解] 取的底数必须是小于等于n-1的; 那12个数字能通过2^64以内的所有数字; ...
- 【hihocoder 1333】平衡树·Splay2
[题目链接]:http://hihocoder.com/problemset/problem/1333 [题意] [题解] 伸展树; 要求提供操作: 1.插入一个元素,两个权值,id作为查找的比较权值 ...
- 【hihocoder 1329】平衡树·Splay(Splay做法)
[题目链接]:http://hihocoder.com/problemset/problem/1329 [题意] [题解] 插入操作:-,记住每次插入之后都要把它放到根节点去就好; 询问操作:对于询问 ...
- 【hihocoder 1329】 平衡树·Splay(set做法)
[题目链接]:http://hihocoder.com/problemset/problem/1329 [题意] [题解] 因为一开始是空的树,所以; n其实就代表了树中的最多元素个数; 则最坏的情况 ...
- 【hihocoder 1476】矩形计数
[题目链接]:http://hihocoder.com/problemset/problem/1476 [题意] [题解] 首先不考虑黑格子,计算出一共有多少个矩形: 枚举矩形的大小r×c,这样大小的 ...
随机推荐
- springboot在lunix后台启动,退出账号也不关闭
首先需要进到自己springboot项目的根目录,然后执行如下linux命令 nohup java -jar 自己的springboot项目.jar >日志文件名.log 2>&1 ...
- vue.js数据绑定语法
原始高清大图下载 1.数据绑定 html代码: <div id="first" class="first">msg:{{msg}}</div& ...
- MVC的viewPage 通用属性运用。
试想下在MVC的前端页面JS或者html中需要使用多语言,而后端的多语言是维护在资源文件中的,前端如果使用的话需要使用AJAX频繁的获取,一个页面中可能会存在大量的需要语言转换的地方,频繁使用AJAX ...
- 【翻译转载】【官方教程】Asp.Net MVC4入门指南(6):验证编辑方法和编辑视图
本节中,您将开始修改为电影控制器所新加的操作方法和视图.然后,您将添加一个自定义的搜索页. 在浏览器地址栏里追加/Movies, 浏览到Movies页面.并进入编辑(Edit)页面. Edit(编辑) ...
- Java_面向对象的 static 和 abstract
static:表示静态的 static:可以用来修饰属性.方法.代码块(或初始化块).内部类. 一.static修饰属性(类变量): public class TestStatic { //stati ...
- QrenCode : linux命令行下生成二维码图片
原文链接:http://wowubuntu.com/qrencode.html # 作者:riku/ / 本文采用CC BY-NC-SA 2.5协议授权,转载请注明本文链接. 对于二维码大家应该并不陌 ...
- vue2.0:(七)、vue-resource
本篇文章开始前,先介绍下什么是vue-resource,并且现在还有一个axios. Vue.js是数据驱动的,这使得我们并不需要直接操作DOM,如果我们不需要使用jQuery的DOM选择器,就没有必 ...
- CSS font-family 字体名称一览表
windows常见内置中文字体 字体中文名 字体英文名 宋体 SimSun(浏览器默认) 黑体 SimHei 微软雅 ...
- 小白学phoneGap《构建跨平台APP:phoneGap移动应用实战》连载五(使用PhoneGap获取设备信息)
除了能够将HTML页面打包成可以直接安装运行的APP外,PhoneGap的一个最大优势在于可以通过JavaScript调用设备来访问设备上的硬件信息,从而实现一些原本只有依靠原生SDK才能够达到的目的 ...
- pod install Pull is not possible because you have unmerged files.
http://stackoverflow.com/questions/21474536/podfile-gives-an-error-on-install A bug was found in lib ...