黑马程序员技术交流社区
标题:
果然大意不得。。if的判断后要==而不是=。。。
[打印本页]
作者:
冥夜
时间:
2014-11-1 14:08
标题:
果然大意不得。。if的判断后要==而不是=。。。
本帖最后由 冥夜 于 2014-11-1 14:27 编辑
24期技术分的题目,能够生成随机生成98个不重复的0-99的数了,但是查找缺失的两个数的时候编译通过无输出。。然后找了半个小时不知道哪里出错了。其中getRandomArray(98)是获取98个不重复的数。
import java.util.Arrays;
public class Jishu24
{
public static void main(String[] args)
{
Jishu24 js = new Jishu24();
int[] a=js.getRandomArray(98);
Arrays.sort(a);
System.out.print("生成的数组是:[");
for(int i=0;i<98;i++)
{
System.out.print(a[i]+" ");
}
System.out.println("]");
System.out.print("缺失的数字是[");
for(int i=0;i<100;i++)//从0到99遍历
{
boolean found=false;
for(int j=0;j<98;j++)//遍历数组
{
if(i==a[j])
{
found=true;
break;
}
}
if(found=false)
{
System.out.print(i+" ");
}
}
System.out.print("]");
}
复制代码
作者:
冥夜
时间:
2014-11-1 14:24
谢谢。。找到问题了。。第28行应该是==而不是=。。。。。。ORZ。。。。
作者:
zhangyangLengen
时间:
2014-11-1 14:28
嗯,if(found=false) 其实永远为false
作者:
眸眼前缘
时间:
2014-11-1 15:58
很多时候一个小问题就是要找半天。
作者:
郑飞
时间:
2014-11-1 18:56
确实有点悲剧 这个变量要是其他类型还好说 正好是boolean :L
作者:
zaneleo
时间:
2014-11-1 19:14
大意了……以后注意细节!
作者:
☆枫の云
时间:
2014-11-2 09:28
这个确实有点坑,不过=是赋值,Eclipse应该会报错
作者:
Hosing
时间:
2014-11-2 10:08
小差异,大不同!:lol
作者:
刘一博
时间:
2014-11-2 10:26
直接if(found)不就好了吗
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2