版权声明:转载请附上原文链接哟! https://blog.csdn.net/weixin_44170305/article/details/90139125
不恋尘世浮华,不写红尘纷扰,不叹世道苍凉,不惹情思哀怨,闲看花开,静待花落,冷暖自知,干净如始。
题目描述
编写函数 int fun(int x, int *pp)。其功能是,求出x的所有奇数因子,并按照从小到大的顺序放在pp指向的内存中,函数返回值为这些整数的个数。若x的值为30,数组中的数为1,3,5,15,函数返回4。
用下面的main()函数进行测试: 提交时提交全部代码
/*C++*/
int main()
{
int a[50],x,n;
cin>>x;
n=fun(x,a);
cout<<n<<endl;
for(int i=0; i<n; i++)
cout<<a[i]<<" ";
cout<<endl;
return 0;
}
/*C语言*/
int main()
{
int a[50],x,n;
scanf("%d",&x);
n=fun(x,a);
printf("%d\n",n);
for(int i=0; i<n; i++)
printf("%d ",a[i]);
printf("\n");
return 0;
}
输入
一个整数
输出
输入的整数的奇因子个数,以及这些奇因子
样例输入
copy
30
样例输出
4 1 3 5 15
#include<stdio.h>
int fun(int x, int *pp);
int main()
{
int a[50],x,n;
scanf("%d",&x);
n=fun(x,a);
printf("%d\n",n);
for(int i=0; i<n; i++)
printf("%d ",a[i]);
printf("\n");
return 0;
}
int fun(int x, int *pp)
{
int i,sum=0;
for(i=1; i<x; i=i+2)
{
if(x%i==0)
{
sum++;
*pp=i;
pp++;
}
}
return sum;
}