题:
下面的字符串包含多个单词,每个单词由 hash(#) 分隔。用#分割每个单词后,
输入:my#name#is#manan 输出:ym 1m2n s1 n1n2m
我的代码是:
import java.lang.*;
import java.io.*;
import java.util.*;
class StrSplit {
public static void main(String[] args) {
String sentence = "my#name#is#manan";
String[] word = sentence.split("#");
String[] reverseword = new String[word.length];
for (int i = 0; i < word.length; i++) {
StringBuilder revword = new StringBuilder(word[i]); // METHOD FOR USING .reverse()
revword.reverse(); // REVERSING
reverseword[i] = revword.toString(); // SAVING REVERSED WORDS INTO AN ARRAY.
}
for (int i = 0; i < reverseword.length; i++) {
int counter = 1;
String current = reverseword[i]; //SELECTING A WORD
for (int j = 0; j < current.length(); j++) {
char ch = current.charAt(j); //SELECTING A CHARACTER
char count=(char)(counter+ '0'); //VOWEL COUNTER
if (ch == 'a' || ch == 'e' || ch == 'i' || ch == 'o' || ch == 'u') {
current = current.replace(current.charAt(j),count); //REPLACE VOWEL WITH NUMBER
counter++;
}
}
counter=1;
StringBuilder output= new StringBuilder(current);
output.append(' ');
System.out.print(output);
}
}
}
但是我的输出中有一个错误。我的输出是:
ym 1m2n s1 n1n1m
虽然它应该是:
ym 1m2n s1 n1n2m
问题是,如果元音不同,计数器只会增加。
current.replace(current.charAt(j),count)
替换所有出现的current.charAt(j)
,所以如果同一个元音出现多次,你可以在一次调用中替换它的所有出现,并且只增加一次计数器。
如果你改变,你可以只替换第一次出现
current = current.replace(current.charAt(j),count);
到
current = current.replaceFirst(current.substring(j,j+1),Integer.toString(counter));
这样,对于每个替换的字符,计数器将增加一次。
现在输出是:
ym 1m2n s1 n1n2m
请注意,replaceFirst()
需要String
参数,而不是char
.
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句