C++break语句问题 break语句的一旦执行不是应该直接跳出循环吗?为什么在我的这个程序里break执行后m总是1
#include<iostream>usingnamespacestd;voidmain(){intn,m;cout<<"判断输入的整数是否为素数,请输入整数N:";ci...
#include<iostream>
using namespace std;
void main()
{
int n,m;
cout<<"判断输入的整数是否为素数,请输入整数N:";
cin>>n;
m=n-1;
for(m;m>1;m--)
{
if(n%m==0)
{cout<<"N不是素数"<<endl;break;}
}
if(m=1)
cout<<"N是素数"<<endl;
system("pause");
} 展开
using namespace std;
void main()
{
int n,m;
cout<<"判断输入的整数是否为素数,请输入整数N:";
cin>>n;
m=n-1;
for(m;m>1;m--)
{
if(n%m==0)
{cout<<"N不是素数"<<endl;break;}
}
if(m=1)
cout<<"N是素数"<<endl;
system("pause");
} 展开
4个回答
展开全部
不是那个break的问题,我改了如下:
#include<iostream>
using namespace std;
void main()
{
int n,m;
cout<<"判断输入的整数是否为素数,请输入整数N:";
cin>>n;
m=n-1;
for(m;m>1;m--)
{
if(n%m==0)
{cout<<"N不是素数"<<endl;break;}
}
if(m == 1) cout<<"N是素数"<<endl;
system("pause");
}
你是将那个赋值符号“=”与等号“==”搞混了,把那个if(m = 1) 改成 if(m == 1)就可以了!
#include<iostream>
using namespace std;
void main()
{
int n,m;
cout<<"判断输入的整数是否为素数,请输入整数N:";
cin>>n;
m=n-1;
for(m;m>1;m--)
{
if(n%m==0)
{cout<<"N不是素数"<<endl;break;}
}
if(m == 1) cout<<"N是素数"<<endl;
system("pause");
}
你是将那个赋值符号“=”与等号“==”搞混了,把那个if(m = 1) 改成 if(m == 1)就可以了!
展开全部
if(m=1)!
应该是if(m==1)
建议你用好一点的IDE 带纠错的,不然这些小错误很难发现
比如 eclipse CDT
应该是if(m==1)
建议你用好一点的IDE 带纠错的,不然这些小错误很难发现
比如 eclipse CDT
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
if(m=1) cout<<"N是素数"<<endl; 这句话有误,应该为: if(m==1) cout<<"N是素数"<<endl; 把"=="写成"="是很容易犯的错误,建议写成 if(1==m)。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
貌似break不能用在这里吧,break有固定的用法。。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询