我正在尝试编写一个使用randomgenerator创建随机单词的程序。但是我如何将随机生成器生成的字符添加到字符串中?而“a:z”对吗?或者如何告诉生成器使用a和z之间的所有数字
public class StringTraining extends ConsoleProgram {
public void run() {
String s1 = null;
randomChar();
s1.concat(randomChar());
println(s1);
}
private String randomChar() {
String word = rgen.nextBoolean() ? "a" : "z";
return word;
}
答案 0 :(得分:0)
Java String
是不可变的,因此您无法以任何方式修改字符串。 s1.concat(...)
会返回一个新的String
对象。如果需要,您可以执行s1=s1.concat(...)
之类的操作,或者如果需要一些性能,可以使用实现可变字符串的StringBuffer
类。
答案 1 :(得分:0)
(condition) ? ifTrue : ifFalse
这就是你的方法正在做什么。你说"如果我们生成一个真实的陈述,我们使用a,如果我们生成一个假,我们使用z。"
听起来你想在a到z的RANGE中使用随机字符。最干净的方法可能是使用字符并从一个范围生成一个数字。
内部字符与整数几乎相同,您可以在其中添加字符以增加可能的字符。因此,您只想生成范围' a'到了'。自从我触及java以来已经有一段时间了,所以我不知道是否有一种简单的方法可以做到这一点。但是如果你想以一种稍微杂乱的方式来查找那些为你做这件事的库,那么你可以从' a'开始。并生成0到25之间的随机数(包括),并将结果添加到' a'。 '一个'例如,+ 1将返回' b'
然后将这个角色附加到你的单词上,你就可以了!
注意:字符和字符串不同。此逻辑不适用于字符串。您需要使用单引号而不是双引号来初始化您的' a'作为一个角色。
答案 2 :(得分:0)
我今天真的花了很多时间来做这个有趣的学习经历。也许其他人可以给出比我更优雅的答案,但这就是我做到的。
public static String getString(){
char[] result = new char[10];
for(int a=0; a<result.length; a++){
result[a] = getLetter();
}
return new String(result);
}
public static char getLetter(){
boolean case = true;
if((1 + (Math.random() * 2) == 2){
case = false;
}
if(case){
switch((int) (1 + (Math.random() * 26))){
case 1:
return 'a';
case 2:
return 'b';
case 3:
return 'c';
case 4:
return 'd';
case 5:
return 'e';
case 6:
return 'f';
case 7:
return 'g';
case 8:
return 'h';
case 9:
return 'i';
case 10:
return 'j';
case 11:
return 'k';
case 12:
return 'l';
case 13:
return 'm';
case 14:
return 'n';
case 15:
return 'o';
case 16:
return 'p';
case 17:
return 'q';
case 18:
return 'r';
case 19:
return 's';
case 20:
return 't';
case 21:
return 'u';
case 22:
return 'v';
case 23:
return 'w';
case 24:
return 'x';
case 25:
return 'y';
case 26:
return 'z';
}
}else{
switch((int)(1 + (Math.random() * 26))){
case 1:
return 'A';
case 2:
return 'B';
case 3:
return 'C';
case 4:
return 'D';
case 5:
return 'E';
case 6:
return 'F';
case 7:
return 'G';
case 8:
return 'H';
case 9:
return 'I';
case 10:
return 'J';
case 11:
return 'K';
case 12:
return 'L';
case 13:
return 'M';
case 14:
return 'N';
case 15:
return 'O';
case 16:
return 'P';
case 17:
return 'Q';
case 18:
return 'R';
case 19:
return 'S';
case 20:
return 'T';
case 21:
return 'U';
case 22:
return 'V';
case 23:
return 'W';
case 24:
return 'X';
case 25:
return 'Y';
case 26:
return 'Z';
}
}
return '\0';
}