杭电 ACM steps 216结题报告.doc
上传人:sy****28 上传时间:2024-09-14 格式:DOC 页数:3 大小:14KB 金币:16 举报 版权申诉
预览加载中,请您耐心等待几秒...

杭电 ACM steps 216结题报告.doc

杭电ACMsteps216结题报告.doc

预览

在线预览结束,喜欢就下载吧,查找使用更方便

16 金币

下载此文档

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

杭电ACMsteps2.1.6解题报告#include<iostream>usingnamespacestd;intfun(intn);intmain(){intt,n,i,k;while(cin>>t){for(i=0;i<t;i++){cin>>n;k=fun(n);cout<<k<<endl;}}return0;}intfun(intn){inti,a;a=1;for(i=2;i*i<=n;i++)if(n%i==0){n=n/i;a=a*(i-1);while(n%i==0){n=n/i;a=a*i;}}if(n>1)a=a*(n-1);returna;}这个题的是实质是求一个数和比它小的正整数是否有公约数。如果有公约数,则为新朋友,否则为老朋友。我们可以把这个数除以这个正整数,然后的把除后的值又重新赋值给这个数,依次循环的进行下去,直到这个数模次正整数为不为0时,次正整数自加,然后又作上述循环,知道次正整数的平方比这个数的原始值大时,这个数比1还打,那么肯定无公约数,这个数即为新朋友。