用c语言求一个数的所有因子

 我来答
阿鑫聊生活
高粉答主

2020-03-18 · 生活知识分享小达人,专注于讲解生活知识。
阿鑫聊生活
采纳数:1217 获赞数:235245

向TA提问 私信TA
展开全部

#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;i<count;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)。



爱路路是我e88f
高粉答主

2018-03-31 · 每个回答都超有意思的
知道小有建树答主
回答量:117
采纳率:100%
帮助的人:28.5万
展开全部

#include<stdio.h>

void main()

{

int a,i=1;       /*先定义两个变量a和i,i的初值为1(因为一个数的因子包括1)*/

scanf("%d",&a);  /*输入想求的数*/

while(i<a)       /*循环条件(当i小于a时(不包括等于a,因为一个数的因子不包括本身))*/

{

if(a%i==0)        /*当i可以被a整除时输出i(这时输出的i即为a的因子)*/

printf("%d,",i);

i++;            /*变量i的值加1*/                

}

printf("\n");       

}

include<stdio.h>

void main()

{int num,i;

scanf("%d",&num);

for (i=1;i<num+1;i++)

if (num%i==0)

printf("%d   ",i);

}

num为你要求的数,num如果能被i整除,那么输出i

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友b79519e
推荐于2018-02-22 · TA获得超过3400个赞
知道大有可为答主
回答量:1417
采纳率:100%
帮助的人:1446万
展开全部
#include<stdio.h>
void main()
{int num,i;
scanf("%d",&num);
for (i=1;i<num+1;i++)
if (num%i==0)
printf("%d ",i);
}
num为你要求的数,num如果能被i整除,那么输出i
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
mu_soso
2011-03-29
知道答主
回答量:9
采纳率:0%
帮助的人:0
展开全部
#include<stdio.h>
void main()
{
int a,i=1; /*先定义两个变量a和i,i的初值为1(因为一个数的因子包括1)*/
scanf("%d",&a); /*输入想求的数*/
while(i<a) /*循环条件(当i小于a时(不包括等于a,因为一个数的因子不包括本身))*/
{
if(a%i==0) /*当i可以被a整除时输出i(这时输出的i即为a的因子)*/
printf("%d,",i);
i++; /*变量i的值加1*/
}
printf("\n");
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
lordspring6
2011-04-04 · TA获得超过219个赞
知道答主
回答量:45
采纳率:0%
帮助的人:44万
展开全部
首先说一下,一、二楼的方向是正确的。但是有个明显的缺陷,程序做了很多无用功。当输入的数据非常之大时,就明显了。举个例子,对10000求解。我写的程序只需要计算100次,而他们的则要计算10000次!!!
#include<stdio.h>
#include<math.h>
void main()
{
int a,i=1;
printf("请输入一个非负整数:");
scanf("%d",&a);
while(i<(sqrt(a)+1))
{
if(a%i==0)
{
printf("%4d",i);
if(a/i!=i)
printf("%4d",a/i);
}
i++;
}
printf("\n");
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式