0

我有一个字符串(“恐龙”),但我不完全知道如何,但是我如何获得字符“o”的位置,是否有可能获得两个位置,就像我的字符串是(“水池”)

4

6 回答 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 回答