yukicoder No.81 - すべて足すだけの簡単なお仕事です。

Source

ニコニコミュニティ
問題文

問題概要

$N$ 個の,整数,または,小数点以下 $10$ 桁までの有限小数 $A_1,A_2,\ldots,A_N$ が与えられる.
和 $A_1+A_2+\cdots+A_N$ を小数点以下 $10$ 桁まで求める問題.

解法

任意精度の実数や整数を用いて(実装して)計算すれば良い.
小数部分と,整数部分に分け,それぞれを $64$ ビット整数型で保持するのが楽だったみたい.

C++によるスパゲッティなソースコード

#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)

ログイン: