隐藏页面特效

2804 最大最小数质因数

2804 最大最小数质因数

 

 时间限制: 1 s
 空间限制: 64000 KB
 题目等级 : 黄金 Gold
 
 
 
题目描述 Description

    先输入n,n<=20;再依次输入n个不同的数,每个数<=1000000;找出最大数和最小数,并输出最大最小数的质因数,没有质因数则输出0。

输入描述 Input Description

数n,空行,输入n个数,每个数中间空行;

输出描述 Output Description

最大数的质因数,每个数中间空格;
最小数的质因数,每个数中间空格.

样例输入 Sample Input

2
15 6

样例输出 Sample Output

3 5
2 3

数据范围及提示 Data Size & Hint

题解:
注意读题。
AC代码:
#include<cstdio> #include<cstring> #include<cmath> #include<algorithm> using namespace std; const int N=1e7+10; int n,maxn,minn=0x7fffffff; bool check[N]; int cnt,ans[N]; void first(){ n=4e6+50; int m=sqrt(n+0.5); for(int i=2;i<=m;i++){ if(!check[i]){ for(int j=i*i;j<=n;j+=i){ check[j]=1; } } } } int main(){ first(); scanf("%d",&n); for(int i=1,x;i<=n;i++){ scanf("%d",&x);maxn=max(maxn,x);minn=min(minn,x); } int t1=maxn,t2=minn; for(int i=2;;i++){ if(t1==1) break; while(t1%i==0) t1/=i,ans[++cnt]=i; } if(!check[maxn]&&ans[cnt]==maxn) ans[cnt--]=0; cnt=unique(ans+1,ans+cnt+1)-(ans+1); if(cnt) for(int i=1;i<=cnt;i++) printf("%d ",ans[i]); else puts("0"); putchar('\n');cnt=0; memset(ans,0,sizeof ans); for(int i=2;;i++){ if(t2==1) break; while(t2%i==0) t2/=i,ans[++cnt]=i; } if(!check[minn]&&ans[cnt]==minn) ans[cnt--]=0; cnt=unique(ans+1,ans+cnt+1)-(ans+1); if(cnt) for(int i=1;i<=cnt;i++) printf("%d ",ans[i]); else puts("0"); return 0; }

 


__EOF__

本文作者shenben
本文链接https://www.cnblogs.com/shenben/p/5967786.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   神犇(shenben)  阅读(438)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
点击右上角即可分享
微信分享提示