请编写函数void fun(int x,int pp[],int*n),它的功能是:求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。 例如,若x中的值为30,则有4个数符合要求,它们是1、3、5

admin2020-06-29  34

问题 请编写函数void fun(int x,int pp[],int*n),它的功能是:求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。
    例如,若x中的值为30,则有4个数符合要求,它们是1、3、5、1 5。
    注意:部分源程序在文件PROGl.c中。
    请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
    试题程序:
#include
#include
#include
void fun(int x,2nt pp[],int*n)
{
}
void main()
{
  FILE*wf;
  int x,aa[1000],n,i;
  system("CLS");
  printf("\nPlease enter an
integer number:\n");
  scanf("%d",&x);
  fun(x,aa,&n);
  for(i=0;i  printf("%d",aa);
  printf("\n");
/*********found*********/
  wf=fopen("out.dat","w");
  fun(30,aa,&n);
  for(i=0;i  fprintf(wf,"%d",aa);
  fclose(wf);
/*********found*********/
}

选项

答案void fun(int x,int pp[],int*n) { int i,j=0; for(i=1;i<=x;i=i+2) /*i的初始值为0,步长为2,确保i为奇数*/ if(x%i==0)/*将能整除x的数存入数组pp中*/ PP[j++]=i; *n=j;/*传回满足条件的数的个数*/ }

解析 本题考查:偶数的判定方法;整除的实现。
    本题题干信息是:能整除x且不是偶数的所有整数。循环语句中变量i从1开始且每次增2,所以i始终是奇数。
    整除的方法,已经讲过多次,这里就不再赘述了。对于本题目要求的不是偶数的判定方法,即该数对2求余不为0。除本题描述的方法外,还可以通过for循环语句直接把偶数筛出去,确保参与操作的数均为奇数。
转载请注明原文地址:https://kaotiyun.com/show/Ld8p777K
0

最新回复(0)