下列给定程序的功能是:读入一个整数k(2≤k≤10000),输出它的所有质因子(即所有为素数的因子)。例如,若输入整数2310,则应输出2,3,5,7,11。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动main函数,不得增行或删行,也不得更

admin2019-04-14  30

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

选项

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

解析 本题考查:函数定义的格式;if条件的判断语句。这些知识点必须掌握,因为经常考到。
(1)函数定义格式错误,函数定义时后面不能加“;”,所以应该去掉分号。
(2)根据题意可知,if条件语句判断n是否可以整除i,如果不能整除则为质因子,所以if!(n%i)应改为if(!(n%i))。
转载请注明原文地址:https://jikaoti.com/ti/Oqf0FFFM
0

最新回复(0)