TakahiroNakamori

TakahiroNakamori

ナカモリタカヒロ

 
 

Coprime

問題

E – Coprime
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「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 << 62;
// const int INF = 1001001001;

ll gcd(ll a, ll b) {
  if(b == 0)
    return a;
  return gcd(b, a % b);
}

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

  vector<ll> A(N);
  vector<ll> cnt(1000100);
  rep(i, N) {
    cin >> A[i];
    cnt[A[i]]++;
  }

  bool flg = true;
  for(int i = 2; i < 1000100; ++i) {
    int check = 0;
    for(int j = i; j < 1000100; j += i) {
      check += cnt[j];
    }
    if(1 < check) {
      flg = false;
      break;
    }
  }
  if(flg) {
    cout << "pairwise coprime" << endl;
    return 0;
  }

  ll g = 0;
  rep(i, N) {
    if(i == 0) {
      g = A[0];
    } else {
      g = gcd(g, A[i]);
    }
  }
  if(g == 1) {
    cout << "setwise coprime" << endl;
    return 0;
  } else {
    cout << "not coprime" << endl;
    return 0;
  }

  return 0;
}