$N$ 個の,整数,または,小数点以下 $10$ 桁までの有限小数 $A_1,A_2,\ldots,A_N$ が与えられる.
和 $A_1+A_2+\cdots+A_N$ を小数点以下 $10$ 桁まで求める問題.
任意精度の実数や整数を用いて(実装して)計算すれば良い.
小数部分と,整数部分に分け,それぞれを $64$ ビット整数型で保持するのが楽だったみたい.
#include<bits/stdc++.h>
using namespace std;
#define REP(i,a,b) for(i=a;i<b;i++)
#define rep(i,n) REP(i,0,n)
#define mygc(c) (c)=getchar_unlocked()
#define mypc(c) putchar_unlocked(c)
void reader(int *x){int k,m=0;*x=0;for(;;){mygc(k);if(k=='-'){m=1;break;}if('0'<=k&&k<='9'){*x=k-'0';break;}}for(;;){mygc(k);if(k<'0'||k>'9')break;*x=(*x)*10+k-'0';}if(m)(*x)=-(*x);}
int reader(char c[]){int i,s=0;for(;;){mygc(i);if(i!=' '&&i!='\n'&&i!='\r'&&i!='\t'&&i!=EOF) break;}c[s++]=i;for(;;){mygc(i);if(i==' '||i=='\n'||i=='\r'||i=='\t'||i==EOF) break;c[s++]=i;}c[s]='\0';return s;}
char res[10000];
int N;
int len; int in[1000]; char buf[1000];
string str;
int main(){
int i, j, k;
int fg;
reader(&N);
while(N--){
len = reader(buf);
reverse(buf,buf+len);
str = buf;
rep(i,str.size()) if(str[i]=='.') break;
if(i==str.size()) str = "." + str;
for(;;){
rep(i,str.size()) if(str[i]=='.') break;
if(i==10) break;
str = "0" + str;
}
fg = 1;
if(str[str.size()-1]=='-'){
fg = -1;
str = str.substr(0, str.size()-1);
}
str = str.substr(0,10) + str.substr(11);
rep(i,str.size()) in[i] += fg * (str[i]-'0');
}
rep(i,777) in[i+1] += in[i] / 10, in[i] %= 10;
for(i=888;i>=0;i--) if(in[i]) break;
if(in[i]<0){
mypc('-');
rep(i,1000) in[i] *= -1;
}
rep(i,999){
in[i+1] += in[i]/10, in[i] %= 10;
if(in[i] < 0) in[i] += 10, in[i+1]--;
}
fg = 0;
for(i=888;i>=0;i--){
if(in[i] || i==10) fg = 1;
if(fg){
mypc(in[i]+'0');
}
if(i==10) mypc('.');
}
return 0;
}
Current time: 2024年03月29日01時03分27秒
Last modified: 2015年01月28日23時48分56秒 (by laycrs)
Tags: Competitive_Programming yukicoder
トップページに戻る
Logged in as: unknown user (not login)