我有一个字符串(“恐龙”),但我不完全知道如何,但是我如何获得字符“o”的位置,是否有可能获得两个位置,就像我的字符串是(“水池”)
问问题
158 次
6 回答
3
至于您的第一个问题,您可以使用String#indexOf(int)来获取字符串中每个 'o' 的索引。
int oPos = yourString.indexOf('o');
至于你的第二个问题,可以通过创建一个使用String.indexOf(int, int)的方法来获取给定字符的所有位置,跟踪前一个索引,这样你就不会重复搜索字符串的部分。您可以将位置存储在数组或列表中。
于 2012-08-27T00:06:08.400 回答
1
indexOf
与循环一起使用:
String s = "Pool";
int idx = s.indexOf('o');
while (idx > -1) {
System.out.println(idx);
idx = s.indexOf('o', idx + 1);
}
于 2012-08-27T00:14:26.440 回答
0
尝试这个
String s= "aloooha";
char array[] = s.toCharArray();
Stack stack = new Stack();
for (int i = 0; i < array.length; i++) {
if(array[i] == 'o'){
stack.push(i);
}
}
for (int i = 0; i < stack.size(); i++) {
System.out.println(stack.get(i));
}
于 2012-08-27T05:53:35.573 回答
0
您是否尝试过将 String 转换为 char 数组?
int counter = 0;
String input = "Pool";
for(char ch : input.toCharArray()) {
if(ch == 'o') {
System.out.println(counter);
}
counter += 1;
}
于 2012-08-27T01:00:37.477 回答
0
简单地:
public static int[] getPositions(String word, char letter)
{
List<Integer> positions = new ArrayList<Integer>();
for(int i = 0; i < word.length(); i++) if(word.charAt(i) == letter) positions.add(i);
int[] result = new int[positions.size()];
for(int i = 0; i < positions.size(); i++) result[i] = positions.get(i);
return result;
}
于 2012-08-27T00:21:00.980 回答
0
这可能有点过火了,但是嘿;)
String master = "Pool";
String find = "o";
Pattern pattern = Pattern.compile(find);
Matcher matcher = pattern.matcher(master);
String match = null;
List<Integer[]> lstMatches = new ArrayList<Integer[]>(5);
while (matcher.find()) {
int startIndex = matcher.start();
int endIndex = matcher.end();
lstMatches.add(new Integer[] {startIndex, endIndex});
}
for (Integer[] indicies : lstMatches) {
System.out.println("Found " + find + " @ " + indicies[0]);
}
给我
Found o @ 1
Found o @ 2
很棒的是,你也可以找到“oo”
于 2012-08-27T00:21:47.383 回答