十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
程序的执行效率非常高(瞬间就完成):
成都创新互联公司专注于浑源网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供浑源营销型网站建设,浑源网站制作、浑源网页设计、浑源网站官网定制、微信平台小程序开发服务,打造浑源网络公司原创品牌,更为您提供浑源网站排名全网营销落地服务。
#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;
}
题目中未确定因子不包括数字T本身。
#includestdio.h
int main()
{
int T;
scanf("%d",T);
int c[T],i,a,N=0;
for(i=1;i=T;i++)
scanf("%d",c[i]);
for(i=1;i=T;i++){
for(a=1;a=c[i]/2;a++)
if(c[i]%a==0)
N+=a;
printf("%d\n",N);
N=0;
}
return 0;
}
对于整数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
# 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)。
根据你的要求实现代码如下!
#includestdio.h
int main()
{
printf("请输入一个数:");
int a;
scanf("%d",a);
for(int i=2;i=a;){
if(a%i==0i!=a){
printf("%d ,",i);
a=a/i;
}
else if(a%i==0i==a){
printf("%d \n",i);
a=a/i;
}
else i++;
}
return 0;
}