2193. Minimum Number of Moves to Make Palindrome

You are given a string s consisting only of lowercase English letters.

In one move, you can select any two adjacent characters of s and swap them.

Return the minimum number of moves needed to make s a palindrome.

Note that the input will be generated such that s can always be converted to a palindrome.

Example 1:

Input: s = "aabb"
Output: 2
Explanation:
We can obtain two palindromes from s, "abba" and "baab". 
- We can obtain "abba" from s in 2 moves: "aabb" -> "abab" -> "abba".
- We can obtain "baab" from s in 2 moves: "aabb" -> "abab" -> "baab".
Thus, the minimum number of moves needed to make s a palindrome is 2.

Example 2:

Input: s = "letelt"
Output: 2
Explanation:
One of the palindromes we can obtain from s in 2 moves is "lettel".
One of the ways we can obtain it is "letelt" -> "letetl" -> "lettel".
Other palindromes such as "tleelt" can also be obtained in 2 moves.
It can be shown that it is not possible to obtain a palindrome in less than 2 moves.

Constraints:

  • 1 <= s.length <= 2000
  • s consists only of lowercase English letters.
  • s can be converted to a palindrome using a finite number of moves.

题目:给定一串字符串,每步两个相邻的字符可以呼唤,问最少换多少步可以将字符串变成回文。假设字符串肯定可以变成回文。

思路:双指针+贪心算法。指针i, j最开始指向首位和尾位,如果i位和j位相等,则直接i++,j--。如果不相等,则一直从前找到与s[j]相等和从后找到与s[i]相等的位置。比较哪边需要挪动的步骤少则挪动哪步。

代码:

class Solution {
public:
    int minMovesToMakePalindrome(string s) {
        int i = 0, j = s.length()-1, res = 0;
        while(i < j){
            if(s[i] == s[j]){i++; j--;}
            else{
                int i1 = i+1, j1 = j-1;
                while(i1 < j && s[i1] != s[j]) i1++;
                while(j1 > i && s[j1] != s[i]) j1--;
                if(i1-i <= j-j1){
                    res += i1-i;
                    for(int k = i1; k > i; k--){
                        s[k] = s[k-1];
                    }
                    s[i] = s[j];
                } else {
                    res += j - j1;
                    for(int k = j1; k < j; k++){
                        s[k] = s[k+1];
                    }
                    s[j] = s[i];
                }
                i++; j--;
            }
        }
        return res;
    }
};

time: O(N^2). space:O(1)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值