请教: 这个程序的一些问题.
产生50以内的质数:(代码如下)#include <stdio.h>
int main (void)
{
int p,i,primes[50],primeIndex=2;
bool isPrime;
primes[0]=2;
primes[1]=3;
for (p=5;p<=50;p=p+2)
{
isPrime=true;
for (i=0;isPrime && p/primes[i]>=primes[i];++i)
if (p%primes[i]==0)
isPrime=false;
if (isPrime==true)
{
primes[primeIndex]=p;
++primeIndex;
}
}
for (i=0;i<primeIndex;++i)
printf("%i ",primes[i]);
printf("\n");
return 0;
}
外循环里面的isPrime=true和内循环里面的isPrime=false还有第二个if语句里面的isPrime==true(注意:前面两个是"="后面个是"==") 现在无论是把其中一个"="改成"=="还是把"=="改成"="都会导致程序结果的错误(编译不会错) 我想问为什么呢?(在这里我都被赋值号和等号弄晕了,)还请大家讲一下.
在内循环里面的i初始值为什么不是0呢,而是1,我试了,i=0结果也是对了,但是我应该正确的应该是i=0啊,他等于1就是从数组的第二个元素开始的,应该从第一个开始嘛.
我怎么也想不通,请大家多请教, 谢谢~!
----------------解决方案--------------------------------------------------------
C语言不支持BOOL类型的参数。
用define标注下。
----------------解决方案--------------------------------------------------------
111
1111 ----------------解决方案--------------------------------------------------------
用define标注了一样的嘛
为什么一换 结果也变了..
对于BOOL变量 等号和赋值不一样 ?
----------------解决方案--------------------------------------------------------
赋值判断一样用。我这边没编译器,回去帮你看看。
----------------解决方案--------------------------------------------------------
判断true和false(就是你的==啦),直接写if(isPrime),如果嫌感觉不太舒服的话,if(isPrime!=false)也是对的(当然false,true,bool要有定义咯……)
千万不要写if(isPrime==true),必错误无疑……
----------------解决方案--------------------------------------------------------
没有呀
他的原版就是if(isPrime==true )
我也试了(我用的VC++) 是对的
我就是被他一会儿用"="一会儿用"==" 给搞晕了...
----------------解决方案--------------------------------------------------------
这里是C版,你说的是C++……
true,false,bool是C++的东西,C如果要用,载入stdbool.h头文件
----------------解决方案--------------------------------------------------------
c99 支持 bool
_Bool 类型
----------------解决方案--------------------------------------------------------
换到c++里就好了哈
----------------解决方案--------------------------------------------------------