嗨,我正忙着编写一个程序来检查(在终端内)您的输入是否是回文(对不起,变量是荷兰语),但我遇到的问题是即使我将字符串反转并且在 if 函数中输入应该与反向输入匹配(例如:便便),但它仍然告诉我:Nee,ga naar huis 的探测器 opnieuw(翻译:不,再试一次或回家)。现在我回家了,我该如何解决它才能给出准确的结果?
此外,我需要用数组计算 a 显示它们的值,计数 b ......等等,直到 9 和空间,你也可以给我一个正确的方向吗?(虽然真的很想知道我的函数出了什么问题,但不需要) public static void main (String[] args) {
String ui = ""; //ui = User Invoer
String palin = "";
String temp = "";
String answer = "";
int uiLength;
int klinkers = 0;
int woorden = 0;
int palinLength;
boolean zoektWoord= true;
Scanner sui= new Scanner(System.in);
System.out.println("Voer een (echte) zin in:");
ui = sui.nextLine().trim();
uiLength = ui.length();
temp=ui.replaceAll( "[^A-Z a-z 0-9]", "");
for (int q = 0; q< temp.length(); q++)
{
char aChar = temp.charAt(q);
if (65 <= aChar && aChar<=90)
{
aChar = (char)( (aChar + 32) );
}
palin+=aChar;
}
for (int qw=0; qw<palin.length(); qw++)
{
if (palin.charAt(qw) == 'a'||
palin.charAt(qw) == 'e'||
palin.charAt(qw) == 'o'||
palin.charAt(qw) == 'i'||
palin.charAt(qw) == 'u')
klinkers ++;
}
for (int x=0; x<palin.length(); x++)
{
if (palin.charAt(x) == ' ')
{
zoektWoord=true;
}
else{
if(zoektWoord) woorden++;
zoektWoord = false;
}
}
String nilap = new StringBuilder(palin).reverse().toString();
/*Als palin PRECIES gelijk is aan het omgekeerde DAN is het een palindroom*/
if (palin==nilap)
{
answer="Jazeker, op de letter";
}
else
{
answer="Nee, probeer opnieuw of ga naar huis";
}
palinLength = palin.length();
System.out.println("Lengte ongefilterde zin: " + uiLength + " karakters" );
System.out.println("Gefilterde zin:\n" + palin );
System.out.println("Lengte gefilterde zin: " + palinLength + " karakters" );
System.out.println("Aantal 'woorden': \t" + woorden );
System.out.println("Aantal klinkers:\t" + klinkers );
System.out.println("Palindroom?\t" + answer );
}
}