Hier ist meine Lösung, syntaktisch hat CodeGym keine Einwände, aber die letzte Bedingung wird angeblich nicht erfüllt.
kann mir jemand sagen, warum?
kann mir jemand sagen, warum?
package de.codegym.task.task08.task0823;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
/*
Landesweite Restaurantkette
*/
public class Solution {
public static void main(String[] args) throws IOException {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
String s = reader.readLine();
//schreib hier deinen Code
char[] strArr = s.toCharArray();
if(Character.isLetter(strArr[0]))
Character.toUpperCase(strArr[0]);
for(int i = 1; i < strArr.length; i++){
if(strArr[i-1] == ' ' && Character.isLetter(strArr[i]))
Character.toUpperCase(strArr[i]);
}
String s2 = Arrays.toString(strArr);
System.out.println(s2);
}
}
Betreffs der Ausgabe durch die toString-Funktion - wieder was gelernt.
Dass das mit dem Character.toUpperCase(strArr[i]) so nicht geht, hätte ich mir ja denken können.
Muss man das mit der booleschen Variablen so machen? Ich finde es übersichrlicher und weniger komplex, auf die 0 gesondert einzugehen.
Mit String.toUpperCase() ist es aber deitlich komplizierter als mit der Character-Klasse.