天天看点

Codeforces 582 A

​​传送门​​

题目大意

有一个长度为的数列,它可以生成一个的数表,数表的第行第列存放的数字是 即和的最大公因数。

一个例子:

Codeforces 582 A

举个例子,上面那个表,就是由数列生成的。

思路

代码

ll gcd(ll a,ll b){
  return !b?a:gcd(b,a%b);
}

int a[maxn],b[maxn];
map<int,int>mp;
map<int,int>::iterator it;
int cmp(int a,int b){
  return a>b;
}
int main(){
  int n;
  cin>>n;
  for(int i=1;i<=n*n;i++){
    scanf("%d",&a[i]);
    mp[a[i]]++;
  }
  
  sort(a+1,a+1+n*n,cmp);
  int cnt=0;
  for(int i=1;i<=n*n;i++){
    if(!mp[a[i]]) continue;
    mp[a[i]]--;
    for(int j=1;j<=cnt;j++){
      mp[gcd(a[i],b[j])]-=2;
    }
    b[++cnt]=a[i];
  }
  for(int i=1;i<=cnt;i++){
    printf("%d ",b[i]);
  }
}