为了账号安全,请及时绑定邮箱和手机立即绑定

我觉得这个do while是个死循环,flags里的任何元素申明时都是为false,进入do while后条件也是为false,那不会一直循环下去,求大神分析

char[] chs = new char[5];

        char[] letters = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',

                'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V',

                'W', 'X', 'Y', 'Z' };

        boolean[] flags = new boolean[letters.length];

                for (int i = 0; i < chs.length; i++) {

            int index;

            do {

                index = (int) (Math.random() * (letters.length));

            } while (flags[index]);// 判断生成的字符是否重复

            chs[i] = letters[index];

            flags[index] = true;

        }

        return chs;


正在回答

1 回答

有执行过吗?我感觉应该无法执行,flags声明时有分配空间,但没有赋值,所以第一次for循环中的while的判断条件flags[index]无法进行判断吧。

我的理解,这个程序的本意是要任意生成不重复的5个字符。

0 回复 有任何疑惑可以回复我~
#1

慕粉3856460 提问者

我觉得会进入死循环,可答案就是这么写的啊!我是把答案复制过来的,有点懵了,我把条件改为==true,就好了
2016-09-16 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

我觉得这个do while是个死循环,flags里的任何元素申明时都是为false,进入do while后条件也是为false,那不会一直循环下去,求大神分析

我要回答 关注问题
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号