给定程序MODI1.C的功能是:读入一个整数k(2≤k≤10000),打印它的所有质因子(即所有为素数的因子)。 例如,若输入整数:2310,则应输出:2、3、5、7、11。 请改正程序中的语法错误,使程序能得出正确的结果。 注意:

admin2019-04-04  35

问题 给定程序MODI1.C的功能是:读入一个整数k(2≤k≤10000),打印它的所有质因子(即所有为素数的因子)。
    例如,若输入整数:2310,则应输出:2、3、5、7、11。
    请改正程序中的语法错误,使程序能得出正确的结果。
    注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!
#include  
/**********found**********/
IsPrime  (int n);
{  int i,m;
    m=1;
    for  (i=2;  i/**********found**********/
    if    !(n%i)
    {  m=0;break;)
    return(m);
  }
  main()
  {  int j,k;
    printf("\nPlease enter an integer
number between 2 and 10 000:  ");
scanf("%d",&k);
    printf("\n\nThe prime factor(s)
of%d is(are):",  k);
    for(j=2;j<=k;j++)
    if((!(k%j))&&(IsPrime(j))  )
printf("\n%4d",j);
    printf("\n");
  }

选项

答案(1)IsPrime(irit n) (2)if(!(n%i))

解析 函数功能是求整数n的素数因子,IsPrime自定义函数的功能是判断i是否为素数。
    (1)第一个标识下面的“IsPrime(int n);”在程序中显然是一个函数,因此应将后面的分号去掉。
    (2)第二个标识下面的if语句后面缺少括号,因此,if!(n%i)应改为if(!(n%i))。
    该题主要考查标点符号、运算符、基本定义。
转载请注明原文地址:https://kaotiyun.com/show/o9Rp777K
0

最新回复(0)