高精度加法
P1601
#include <bits/stdc++.h>
#define int long long
#define PII pair<int,int>
#define endl '\n'
#define LL __int128
using namespace std;
const int N=2e5+10,M=1e3+10;
int a[N],pre[N];
int b[N],c[N];
signed main()
{
std::ios::sync_with_stdio(false);
cin.tie(0);cout.tie(0);
string A,B;
cin>>A>>B;
int len=max(A.length(),B.length());
for(int i=A.length()-1,j=1;i>=0;i--,j++)
a[j]=A[i]-'0';
for(int i=B.length()-1,j=1;i>=0;i--,j++)
b[j]=B[i]-'0';
for(int i=1;i<=len;i++)
{
c[i]+=a[i]+b[i];
c[i+1]=c[i]/10;
c[i]%=10;
}
if(c[len+1])
len++;
for(int i=len;i>=1;i--)
cout<<c[i];
return 0;
}
高精度乘法
P1303
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std;
char a1[10001],b1[10001];
int a[10001],b[10001],c[10001];
int main ()
{
cin>>a1>>b1;
int lena=strlen(a1);
int lenb=strlen(b1);
for(int i=1;i<=lena;i++)a[i]=a1[lena-i]-'0';
for(int i=1;i<=lenb;i++)b[i]=b1[lenb-i]-'0';
for(int i=1;i<=lena;i++)
for(int j=1;j<=lenb;j++)
c[i+j-1]+=a[i]*b[j];
int len=lena+lenb;
for(int i=1;i<len;i++)
{
c[i+1]+=c[i]/10;
c[i]%=10;
}
while(c[len]==0&&len>1)len--;
for(int i=len;i>=1;i--)cout<<c[i];
return 0;
}