首先来看怎么确定高精度的位数,最多有1000各大臣,每个大臣左手数字最大为10000,所以相乘的最差结果就是10^4000,也就是至多是一个4000位的数(大臣手中数字不包括10000)。然后就是基本的高精度乘法和高精度除低精度的除法。
#include<bits/stdc++.h>
using namespace std;
int n;
const int M=4005; //M为高精度位数
struct node{
int a,b,sum;
bool operator<(const node& p)const{
return sum<p.sum;
}
}a[M];
int g[M];
int len=1;
void mul(int x){
for(int i=1;i<=len;i++) g[i]*=a[x].a;
for(int i=1;i<=len;i++){
g[i+1]+=g[i]/10;
g[i]=g[i]%10;
}
len++; //进位后g的长度加一,4000*2这种没进位的也不用担心,去掉前导0的操作会解决
while(g[len]>9){
g[len+1]+=g[len]/10;
g[len]=g[len]%10;
len++;
}
if(g[len]==0) len--;//去掉前导0,前导0只可能有一个,就是类似4000*2这样的情况,虽然len增加,但是没进位
}
void div(){
for(int i=len;i>=1;i--){
g[i-1]+=((g[i]%a[n].b)*10);
g[i]=g[i]/a[n].b;
}
while(g[len]==0) len--; //除法运算可能有多个前导0产生
if(len==0) cout<<1; //重要,是向下取整为0的情况
}
int main(){
cin>>n;
cin>>a[0].a>>a[0].b;
for(int i=1;i<=n;i++){
cin>>a[i].a>>a[i].b;
a[i].sum=a[i].a*a[i].b;
}
sort(a+1,a+1+n);
g[1]=a[0].a;
for(int i=1;i<n;i++) mul(i);
div(); //高精度除法
// cout<<len<<endl;
for(int i=len;i>=1;i--) cout<<g[i];
return 0;
}
高精度乘法单列出来
void mul(int x){
for(int i=1;i<=len;i++) g[i]*=a[x].a;
for(int i=1;i<=len;i++){
g[i+1]+=g[i]/10;
g[i]=g[i]%10;
}
len++; //进位后g的长度加一,4000*2这种没进位的也不用担心,去掉前导0的操作会解决
while(g[len]>9){
g[len+1]+=g[len]/10;
g[len]=g[len]%10;
len++;
}
if(g[len]==0) len--;//去掉前导0,前导0只可能有一个,就是类似4000*2这样的情况,虽然len增加,但是没进位
}
高精度除低精度除法单列出来,注意向下取整为0的情况,如果不特判,那么len被减没后,就输出不出来任何数。
void div(){
for(int i=len;i>=1;i--){
g[i-1]+=((g[i]%a[n].b)*10);
g[i]=g[i]/a[n].b;
}
while(g[len]==0) len--; //除法运算可能有多个前导0产生
if(len==0) cout<<1; //重要,是向下取整为0的情况
}