说我有一个字符串,它可能看起来像:查找单词
“RAHDTWUOPO”
我知道我要找的字,例如:
“WORD”
这将是寻找最好的方法,如果我可以弥补“WORD”包含“RAHDTWUOPO”的字符串
编辑:
因为这个问题是标识不清的认为Id投入更多的细节。我想达到的目的是要找出我之前知道的一个词是否可以由一串随机字母组成。不知道如何去做这个循环,或者是否有其他方法。
我拿出东西很快在我的头,但我知道这是很大的努力,但我把它放在这里做什么,我想实现这个问题更加清晰。
public class MyLetterObject {
private String letter;
private Boolean used;
public String getText() {
return letter;
}
public void setLetter(String letter) {
this.letter = letter;
}
public Boolean getUsed() {
return used;
}
public void setUsed(Boolean used) {
this.used = used;
}
}
boolean ContainsWord(String Word, String RandomLetterString) {
List<MyLetterObject> MyLetterList = new ArrayList<MyLetterObject>();
for (char ch : RandomLetterString.toCharArray()) {
MyLetterObject mlo = new MyLetterObject();
mlo.setLetter(String.valueOf(ch));
mlo.setUsed(false);
MyLetterList.add(mlo);
}
String sMatch = "";
for (char Wordch : Word.toCharArray()) {
for (MyLetterObject o : MyLetterList) {
if (o.getUsed() == false
&& String.valueOf(Wordch).equals(o.getText())) {
o.setUsed(true);
sMatch = sMatch + String.valueOf(Wordch);
break;
}
}
}
if (sMatch.equals(Word)) {
return true;
} else {
return false;
}
}
正如你可以看到很多努力。叶夫根尼·Dorofeev答案是更加的只是发现如果一个字可以从随机顺序的字母组成的字符串进行的宗旨更好。
什么样的方法你目前考虑的? –
它会采取排列组合,并忘记它。对于一个没有采取任何行动来解决问题的人来说,这太复杂了。 – David
你知道[String.indexOf(字符串str)(http://docs.oracle.com/javase/1.4.2/docs/api/java/lang/String.html#indexOf(java.lang.String中) ) – Parth