Załóżmy, że chcemy przywrócić następujący ciąg "áe".Jak uzyskać odwrotny ciąg (bezpieczny dla Unicode)
Kod Unicode to "\ u0061 \ u0101 \ u0001".
Naiwny aproach od powrotu byłoby char przez char
private static String reverseStringNaive(String s) {
char[] characters = new char[s.length()];
for (int i = s.length() - 1; i >= 0; i--) {
int j = s.length() - i - 1;
characters[j] = s.charAt(i);
}
return new String(characters);
}
który daje nam "EA" (\ u0065 \ u0301 \ u0061), kiedy mamy nadzieję dostać "EA" (\ u0065 \ u0061 \ u0301). Akcent akcentujący "" "należy trzymać razem z" a ", a nie z" e ".
Poniższy kod daje mi oczekiwany wynik dla tego łańcucha:
private static String reverseString(String s) {
char[] characters = new char[s.length()];
for (int i = s.length() - 1; i >= 0; i--) {
int j = s.length() - i - 1;
if (Character.isLetterOrDigit(s.charAt(i)) || Character.isISOControl(s.charAt(i))) {
characters[j] = s.charAt(i);
} else {
characters[j] = s.charAt(i-1);
characters[j+1] = s.charAt(i);
i--;
}
}
return new String(characters);
}
mam sprawdzanie czy każdy znak jest literą, cyfrą lub ISO Control. Jeśli nie, zakładam, że powinna się trzymać z poprzednią postacią.
Pytanie brzmi, czy są inne rzeczy, które powinienem sprawdzić lub obawiać się? Czy mój aproach wciąż jest naiwny?
Co powiesz na http://commons.apache.org/lang/api-2.5/org/apache/commons/lang/StringUtils.html#reverse(java.lang.String)? –
To naiwne podejście. Daje zły wynik. – pablosaraiva
Zgodnie z javadoc, używa 'StringBuffer.reverse()' i powinno to działać zobacz http://download.oracle.com/javase/1.5.0/docs/api/java/lang/StringBuffer.html#reverse () –