十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
1.对1~本身的各个数取余,为零的即为其因子。
建网站原本是网站策划师、网络程序员、网页设计师等,应用各种网络程序开发技术和网页设计技术配合操作的协同工作。创新互联专业提供网站设计、成都网站设计,网页设计,网站制作(企业站、成都响应式网站建设、电商门户网站)等服务,从网站深度策划、搜索引擎友好度优化到用户体验的提升,我们力求做到极致!
#include stdio.h
void factor(int n)
{
printf("%d factor has: ", n);
for (int i = 1; i = n; i ++)
{
if (n % i == 0)
printf("%d ", i);
}
printf("\n");
}
int main()
{
factor(27);
factor(100);
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)。
1.#include stdio.h
int fun(int n)
{
int i;
if(n == 2)
{
printf("是素数\n");
return 0;
}
else if(n = 1)
{
printf("不是素数\n");
return 0;
}
else
{
for(i = 2;i = n/2; i++)
{
if(n % i == 0)
{
printf("不是素数\n");
break;
}
}
if(i == (n/2+1) )
{
printf("是素数\n");
}
}
}
int main()
{
int n;
scanf("%d",n);
fun(n);
}
2.#include stdio.h
int main()
{
int a[10],i,sum=0,max,min;
for(i = 0; i 10; i++ )
{
scanf("%d",a[i]);
}
max=a[0];
min=a[0];
for(i = 1;i = 9;i++)
{
if(maxa[i])
{
max=a[i];
}
}
for(i = 1;i = 9;i++)
{
if(mina[i])
{
min=a[i];
}
}
for(i = 0;i = 9;i++)
{
sum=sum+a[i];
}
sum=sum-max-min;
printf("最终得分为:%d\n",sum);
return 1;
}
3.-102的原码是11100110
反码是10011001
补码是10011010
4.#include stdio.h
int main()
{
int i,n;
int s=1;
scanf("%d",n);
if(n0)
{
return 0;
}
if(n==0)
{
printf("%d的阶乘是:1\n",n);
return 0;
}
for(i=1;i=n;i++)
s=s*i;
printf("%d的阶乘是:%d\n",n,s);
return 0;
}
#includemath.h
int
fun(int
n)
{int
i,k=1;
for(i=2;i=sqrt(n);i++)
if(n%i==0)
k=0;
return
k;}
void
factor(int
n)
{
int
i,x,m=n;
printf("\n%d=",n);
for(i=2;i=n;i++)
{
if(fun(i)==1m%i==0){
printf("%d*",i);
m=m/i;
i=1;
if(fun(m)==1)
break;}
}
printf("%d\n",m);
}
main()
{
int
a;
printf("shu
ru
yi
ge
shu:");
scanf("%d",a);
factor(a);
}
因为一定要是素因数的乘积
所以我多用了一个判断是不是素数的函数,可以不?
如果只能用一个函数,你就自己把fun函数放进去,不过写起来就有点繁了!
一开始定义int m=0没必要,就是m就可以了。
循环中要定义m=0,这样,对于每一个i,m最终都得到i因子的和,然后将m与i比较,如果相等,则i是完数,输出完数i。对于下一个i,m=0的作用是将m及时恢复0,这样才能得到i因子的和,否则就是对于各个i,m的值一直累加了。