重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
#include stdio.h
成都创新互联服务项目包括商南网站建设、商南网站制作、商南网页制作以及商南网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,商南网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到商南省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
# include stdlib.h
#define N 100
long factor(int m,int fac[],int *cp){
int c1,c2,i,k;
long s;
fac[0]=1;
for(c1=s=1,c2=N-1,i=2;;){
k=m/i;
if(m%i==0){
if(i!=k){
fac[c1++]=i;
fac[c2--]=k;
s+=i+k;
printf("i=%d k=%d\n",i,k);
}else{
fac[c1++]=i;
s+=i;
}
}
i++;
if(i=k) break;//这个时候k已经开始等于自身的根号,或者将要出现和之前k对称的i,引起自身重复故退出
}
for(c2++;c2=N-1;c2++){
fac[c1++]=fac[c2];
printf("%s %d\n","**",fac[c2]);
}
*cp=c1;
return s;
}
int main(int argc, char const *argv[])
{
/* code */
int factors[N],i,count;
long sum;
sum = factor(atoi(argv[1]),factors,count);
for(i=0;icount;i++){
printf("%5d",factors[i]);
}
printf("\n\n");
printf("sum=%5ld count=%5d\n",sum,count);
return 0;
}
扩展资料:
有一种说法是“因子不限正负”,不过通常情况下只取正因子。
1, -1, n 和 -n 这些数叫做 n 的明显因子
表示方法:可以用因子|倍数或倍数≡0 (mod 因子) 来表达(参见同余),但用后者时因子一定要是正因子。因子∣倍数 式中的垂直线是整除符号。它的统一码值是 U+2223。
例如 42=6x7,因此 7 是 42 的因子,写作 7∣42,亦是42≡0(mod 7)。
对于整数n,采用循环从1到n-1进行检查,如果检测到是n的因数,则将该数累加起来,最后输出结果即可。参考代码如下:
#include stdio.h
int main()
{
int sum=0;
int n=0;
int i,m=0;
scanf("%d", n ); //输入一个整数
if ( n= 0 ) //只统计正整数
return -1;
printf("1"); //最小的因数是1,必然存在
sum = 1;
for( i=2;in;i++ )
{
if ( n%i==0 ) //能整除,是因子
{
sum += i ; //累加
printf("+%d", i ); //输出该因子
}
}
printf("=%d\n", sum ); //输出因子和
return 0;
}
程序的执行效率非常高(瞬间就完成):
#include "stdio.h"
int fun(int n)
{int i,s=n+1;
for(i=2;i*in;i++)
if(n%i==0)s+=i+n/i;
if(i*i==n)s+=i;
return s;
}
main()
{ int k;
scanf("%d",k);
printf("%d\n",fun(k));
}
#includestdio.h
int main()
{
int n,i,s;
while(scanf("%d",n)!=EOF)
{
s=1; //如果不需要包含1,可改为s=0
printf("因子列表:%d ",s);
for (i=2;i=n/2+1;i++)
{
if(n%i==0)
{
printf("%d ",i);
s+=i;
}
}
printf("\n因子和:s=%d\n",s);
}
return 0;
}