新手守护
题目链接: 酷町堂:1062
/*我的代码*/
#include<iostream>
#include<cmath>
using namespace std;
int n,a[20005],t[5005],maxn,b[20005];
int main(){
for(int i=2;i<=20000;i++){
if(!b[i]){
for(int j=2*i;j<=20000;j+=i){
b[j]=1;
a[j]=max(a[j],i);
}
}
}
cin>>n;
for(int i=1;i<=n;i++){
cin>>t[i];
if(!a[t[i]])
a[t[i]]=t[i];
maxn=max(a[t[i]],maxn);
}
for(int i=1;i<=n;i++){
if(maxn==a[t[i]]){
cout<<t[i];
}
}
return 0;
}
/*正确代码*/
#include<iostream>
#include<cmath>
using namespace std;
int n,t;
int tmp;
int maxn;
int ans;
int main(){
cin>>n;
while(n--){
cin>>t;
tmp=0;
int a=t;
for(int i=2;i<=sqrt(t);i++){
while(t%i==0){
tmp=i;
t/=i;
}
}
if(t!=1)
tmp=t;
if(tmp>maxn){
maxn=tmp ;
ans=a;
}
}
cout<<ans;
return 0;
}