注册 登录
编程论坛 VC++/MFC

C++求质数的问题

jazshihaoren 发布于 2016-06-01 23:21, 3639 次点击
小弟刚接触C++。 求100以内所有的质数。下面是上课老师讲的标准答案。可是我一直弄不懂 为什么不可以  if(i%j!=0)直接表示质数 这样写有啥漏洞?为什么这样写会输出非质数?还有下面的 if(j==i)到底是啥意思 苦思不得其解。



for (int i = 2; i <= 100;i++)
    {
        int j = 2;
        for (; j < i; j++)
        {
            if (i%j == 0)
            {
                cout << i << "不是质数" << endl;
                break;
            }

        }

        if (j==i)
        {
            cout << i << "是质数" << endl;

        }
        
    }
1 回复
#2
yangfrancis2016-06-02 07:29
i%j!=0这样写只能说明i不是被某个小于i的数整除,而不能说明2~i-1的所有数都不能将它整除。
比如i执行到9时,j执行到2,会发现9%2!=0, 9就被算作质数了。
1