实现猜字母游戏中的字母生成方法,即,随机生成5个不同的字母作为猜测的结果。
实现generate方法,首先声明一个字符类型的数组,用于存储26个大写字母,然后声明一个boolean类型的数组,其长度也为26。此数组中的初始值均为false,意味着,程序起始,没有任何字母被选中。如果某个字母被选中,则同时设置该字母在boolean类型数组中对应位置上的值为true,表示该字母被选中过。
然后,使用嵌套循环:外层循环用于控制所生成的字母个数,即,循环5次,以产生5个字母;而内层循环则用于判断所生成的字母是否重复。generate方法的程序流程如图所示:
实现此案例需要按照如下步骤进行。
在generate方法中,首先定义char类型的数组变量letters,用于存放26个大写字母,然后定义boolean类型的数组变量flag,flag数组的大小和letters数组的大小相同,用于记载某字母是否被选中,以便于判断字母是否重复。代码如下所示:
public static char[] generate(){
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];
return chs;
}
使用嵌套循环,随机选择5个不同的字母,并且这五个字母不相同。代码如下所示:
public static char[] generate(){
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
很多初学者写程序没有思路,即使有思路也不知道从哪里下手,脑子里一团糟。无论多么复杂的程序,都是由一个个小功能组成。这里的小功能指的就是“方法”,将每一个小功能都封装成方法,完善每一个方法,一个程序就完成了。
generate()方法的关键就在于如何实现不重复,这里用到了flag标记实现了不重复。在其他需要实现不重复的...程序中,也可以用到此思想。