Solution: Minimum Number of Moves to Make Palindrome
Let’s solve the Minimum Number of Moves to Make Palindrome problem using the Two Pointers pattern.
We'll cover the following
Statement
Given a string s
, return the minimum number of moves required to transform s
into a palindrome. In each move, you can swap any two adjacent characters in s
.
Note: The input string is guaranteed to be convertible into a palindrome.
Constraints:
s.length
s
consists of only lowercase English letters.s
is guaranteed to be converted into a palindrome in a finite number of moves.
Solution
The main strategy for solving this problem is to use a two-pointer approach to progressively match characters from the outer ends of the string toward the center, while minimizing adjacent swaps to transform the string into a palindrome. For each character on the left side, the algorithm searches for its matching counterpart on the right side and moves it into place by repeatedly swapping adjacent characters. If a match is found, the right-side pointer moves inward; if no match is found, it indicates that the character is the center of an odd-length palindrome and is positioned accordingly.
Using the above intuition, the solution can be implemented as follows:
Initialize a variable,
moves
, withto keep track of the number of swaps required. Initialize two pointers,
i
at the beginning of the string andj
at the end of the string, to traverse the string from both ends toward the center.At each iteration, the goal is to match the character at position
i
with the corresponding character at positionj
.
Start an inner loop with
k
initialized toj
, which represents the current character at the end of the string. It moves backward fromj
toi
to find a matching character fors[i]
.The loop checks whether
s[i] == s[k]
. If a match is found, we keep swappings[k]
withs[k+1]
untilk
reachesj
. For each swap, increment themoves
counter.After the character is moved to position
j
, decrementj
to continue processing the next character from the end.
If no match is found by the time
k
reachesi
(i.e.,k == i
), it means that the character ati
is the center character of an odd-length palindrome.In this case, the number of moves is incremented by
(s.size() / 2) - i
, which is the number of moves required to bring this unique character to the center of the string. In this case, we don't swap any characters; just updatemoves
.
After processing the entire string, return the value of
moves
, which represents the minimum number of moves needed to transform the input string into a palindrome.
Let’s look at the following illustration to get a better understanding of the solution:
Let’s look at the code for the algorithm we just discussed.
public class Solution {public int minMovesToMakePalindrome(String s) {char[] chars = s.toCharArray();int moves = 0;for (int i = 0, j = chars.length - 1; i < j; ++i) {int k = j;for (; k > i; --k) {if (chars[i] == chars[k]) {for (; k < j; ++k) {char temp = chars[k];chars[k] = chars[k + 1];chars[k + 1] = temp;++moves;}--j;break;}}if (k == i) {moves += chars.length / 2 - i;}}return moves;}// Driver codepublic static void main(String[] args) {List<String> strings = Arrays.asList("ccxx", "arcacer", "w", "ooooooo", "eggeekgbbeg");Solution sol = new Solution();for (int i = 0; i < strings.size(); ++i) {System.out.println((i + 1) + ".\ts: " + strings.get(i));System.out.println("\tMoves: " + sol.minMovesToMakePalindrome(strings.get(i)));System.out.println(new String(new char[100]).replace("\0", "-"));}}}
Time complexity
The algorithm’s time complexity is s
.
The outer loop runs from
Space complexity
The algorithm’s space complexity is
Level up your interview prep. Join Educative to access 70+ hands-on prep courses.