TakahiroNakamori

TakahiroNakamori

中森崇博(ナカモリタカヒロ)

12 /
28
2021
 

コイン

問題

C – コイン
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「AtCoder」。オンラインで毎週開催プログラミングコンテストを開催しています。競技…

記録

解法

コード例

#include <bits/stdc++.h>
using namespace std;
#include <atcoder/all>
using namespace atcoder;
using ll = long long;
using P = pair<int, int>;
#define rep(i, n) for(int i = 0; i < (n); ++i)
// using mint = modint998244353;
// using mint = modint1000000007;
// const int mod = 1000000007;
// const ll INF = 1LL << 60;
// const int INF = 1001001001;

int main() {
  int N;
  cin >> N;

  vector<int> C(N);
  int mx = 0;
  rep(i, N) {
    cin >> C[i];
    mx = max(mx, C[i]);
  }

  sort(C.begin(), C.end());

  double ans = 0.0;

  for(int i = 0; i < N; ++i) {
    // 自分の約数の数
    int cnt = 0;
    for(int j = 0; j < N; j++) {
      if(i != j && C[i] % C[j] == 0) {
        cnt++;
      }
    }
    if(cnt % 2 == 0) {
      ans += (double)(cnt + 2) / (cnt * 2 + 2);
    } else {
      ans += 0.5;
    }
  }

  printf("%.16f", ans);
  printf("\n");
  return 0;
}