时间限制: 1000 ms 空间限制: 262144 KB
题目描述
data:image/s3,"s3://crabby-images/37e7d/37e7d6c1fac4155ceb9156ecb16aa9bb6c3d92c1" alt=""
输入
data:image/s3,"s3://crabby-images/00cf2/00cf24c867f0b07a2efd3f735658275ba5d6c4b0" alt=""
输出
data:image/s3,"s3://crabby-images/241b2/241b279f34e1063b89b57b982e0ba2e827b4e7bf" alt=""
样例输入1
样例输入2
样例输出1
样例输出2
数据范围限制
data:image/s3,"s3://crabby-images/2dc92/2dc92f0ae433a593845025804c87366c37a85e78" alt=""
代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
| #include<bits/stdc++.h> using namespace std; int n,v,k=1,maxx=-0x3f3f3f,a[100001],t[100001],b[100001]; void g(int x) { for(int i=1;i*i<=x;i++) { if(x%i==0) { t[i]++; t[x/i]++; if(i*i==x) t[i]--; } } } int main() { freopen("template.in","r",stdin); freopen("template.out","w",stdout); scanf("%d",&n); for(int i=1;i<=n;i++) { scanf("%d",&v); g(v); if(v>maxx) maxx=v; } for(int i=maxx;i>=1;i--) { while(t[i]>=k) { b[k]=i; k++; } } for(int i=1;i<=n;i++) printf("%d\n",b[i]); return 0; }
|
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 暗影小站! 注: 本博客暂不开设评论区,请使用邮件119548583@qq.com联系