我正在进行Java CodeBat练习。 Here is the one I am stuck on:
在字符串中查找“zip”和“zap”等模式 - 长度为3,以“z”开头,以“p”结尾。返回一个字符串,对于所有这些单词,中间字母不见了,所以“zipXzap”产生“zpXzp”。
这是我的代码:
public String zipZap(String str){
String s = ""; //Initialising return string
String diff = " " + str + " "; //Ensuring no out of bounds exceptions occur
for (int i = 1; i < diff.length()-1; i++) {
if (diff.charAt(i-1) != 'z' &&
diff.charAt(i+1) != 'p') {
s += diff.charAt(i);
}
}
return s;
}
这对其中一些人来说是成功的,但对其他人则不然。对于某些示例字符串,似乎&&
运算符的行为类似于||
;也就是说,我想保留的许多角色都没有被保留。我不确定如何修复它。
如果你愿意的话,向正确的方向轻推!我只需要一个提示!
答案 0 :(得分:2)
实际上它是另一种方式。你应该这样做:
if (diff.charAt(i-1) != 'z' || diff.charAt(i+1) != 'p') {
s += diff.charAt(i);
}
相当于:
if (!(diff.charAt(i-1) == 'z' && diff.charAt(i+1) == 'p')) {
s += diff.charAt(i);
}
答案 1 :(得分:1)
这听起来像正则表达式的完美使用。
正则表达式"z.p"
将匹配以z开头的任何三个字母标记,中间有任何字符,以p结尾。如果您要求它是一封信,您可以使用"z[a-zA-Z]p"
代替。
所以你最终得到了
public String zipZap(String str) {
return str.replaceAll("z[a-zA-Z]p", "zp");
}
顺便说一句,这通过了所有测试。
你可以提出这个问题是关于原始字符串操作的论点,但我认为这使得这更好的一课:正确应用正则表达式是一项非常有用的技能!
答案 2 :(得分:0)
public String zipZap(String str) {
//If bigger than 3, because obviously without 3 variables we just return the string.
if (str.length() >= 3)
{
//Create a variable to return at the end.
String ret = "";
//This is a cheat I worked on to get the ending to work easier.
//I noticed that it wouldn't add at the end, so I fixed it using this cheat.
int minusAmt = 2;
//The minus amount starts with 2, but can be changed to 0 when there is no instance of z-p.
for (int i = 0; i < str.length() - minusAmt; i++)
{
//I thought this was a genius solution, so I suprised myself.
if (str.charAt(i) == 'z' && str.charAt(i+2) == 'p')
{
//Add "zp" to the return string
ret = ret + "zp";
//As long as z-p occurs, we keep the minus amount at 2.
minusAmt = 2;
//Increment to skip over z-p.
i += 2;
}
//If it isn't z-p, we do this.
else
{
//Add the character
ret = ret + str.charAt(i);
//Make the minus amount 0, so that we can get the rest of the chars.
minusAmt = 0;
}
}
//return the string.
return ret;
}
//If it was less than 3 chars, we return the string.
else
{
return str;
}
}