Palindrom¶
Palindrom to wyraz, który czytany od lewej do prawej i od prawej do lewej jest taki sam.
Specification¶
Input¶
- \(n\) — liczba naturalna, długość tekstu, \(n > 0\)
- \(tekst[1..n]\) — ciąg znaków o długości \(n\), numerowanych od jedynki
Output¶
- \(TRUE\) — jeżeli tekst jest palindromem
- \(FALSE\) — w przeciwnym przypadku
Example 1¶
Input¶
Output: TRUE¶
Info
Wyjaśnienie
Wyraz kajak czytany od tyłu to kajak, jest on więc palindromem.
Example 2¶
Input¶
Output: FALSE
Info
Wyjaśnienie
Wyraz tama czytany od tyłu to amat, nie jest on więc palindromem.
Solution¶
Jednym ze sposobów na sprawdzenie, czy wyraz jest palindromem, jest przejście znak po znaku od lewej aż do środka i porównywanie ze znakami od prawej strony. Można to zrealizować za pomocą jednej pętli i odpowiedniego obliczania indeksu znaku "od końca". Dla przykładu, jeżeli mamy wyraz o długości \(6\) znaków, to będziemy ze sobą porównywali parami znaki na pozycjach: \((1, 6), (2, 5), (3, 4)\). W momencie gdy tylko stwierdzimy, że znaki na odpowiadających sobie pozycjach się różnią, możemy zwrócić jako wynik fałsz, ponieważ oznacza to, że wyraz nie jest palindromem. Jeżeli natomiast przejdziemy tak przez wszystkie pary znaków i nie stwierdzimy sprzeczności, to po wyjściu z pętli wiemy, że wyraz jest palindromem, zwracamy więc wartość prawda.
Pseudocode¶
funkcja CzyPalindrom(n, tekst):
1. srodek := n div 2
2. Od i := 1 do srodek, wykonuj:
3. Jeżeli tekst[i] != tekst[n - i + 1], to:
4. Zwróć FALSE
5. Zwróć TRUE
Block diagram¶
%%{init: {"flowchart": {"curve": "linear"}, "theme": "neutral"} }%%
flowchart TD
START(["CzyPalindrom(n, tekst)"]) --> K1["srodek := n div 2
i := 1"]
K1 --> K2{i <= srodek}
K2 -- TRUE --> K3{"tekst[i] != tekst[n - 1 + 1]"}
K3 -- TRUE --> K4[/Zwróć FALSE/]
K4 --> STOP([STOP])
K3 -- FALSE --> K2i[i := i + 1]
K2i --> K2
K2 -- FALSE --> K5[/Zwróć TRUE/]
K5 --> STOP
Complexity¶
\(O(n/2)\to O(n)\) — liniowa
Przechodzimy pętlą od \(1\) do połowy długości wyrazu (czyli do \(\lfloor\frac{n}{2}\rfloor\)) porównując ze sobą odpowiednie pary znaków, stąd złożoność liniowa.