2 supersuperna123 supersuperna123 于 2016.04.06 20:35 提问

求和问题 简单的不能再简单了 可惜有瑕疵

输入 m 和n 求m一直加到n代码如下

# ## #include ********_

# ## int main()

# ## {

# ## int m,n,b=0;

# ## long int sum=0;

# ## scanf("%d%d",&m,&n);

# ## if(n>=m)

# ## {

# ## if(n==m)

# ## {

# ## printf("%d",m);

# ## }

# ## else{

# ## for(;m<=n;m++)

# ## {

# ## sum=sum+m;

# ## }

# ## printf("%ld\n",sum);

# ## }

# ## }

# ## if(n<m){

# ## b=n;

# ## n=m;

# ## m=b;

# ## for(;m<=n;m++)

# ## {

# ## sum=sum+m;

# ## }

# ## printf("%ld",sum);

# ## }

# ## return 0;

# ## }********_

错误的地方在if(m>n)当我把它换成else的时候就对了但是写成if(m>n)不是一个意思
吗? 不知道为什么求解答

3个回答

qq423399099
qq423399099   Ds   Rxr 2016.04.06 21:11
已采纳

只要楼主输入的两个数,前一个比后一个小,也就是满足n>=m
那么会进入第一个if分支,而这个分支里的for循环会对m进行++运算,for循环结束时,m会大于n(大了1)
然后判断第二个if语句,if(n<m)满足,又进入了这个if分支,所以会打印两次(这就是瑕疵所在,改成else就不会进入这个循环,或者不要改变m的值)

szllong123
szllong123   2016.04.06 20:40

我咋没看懂你再说啥,另外scanf时要有个逗号或者空格吧

supersuperna123
supersuperna123 好吧我的语文不太好
一年多之前 回复
dongpengfei1992
dongpengfei1992   2016.04.06 20:48

你应该把你的 “if(n<m)” 改为“else”

supersuperna123
supersuperna123 但是为什么要改恩
一年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!