c++ - 通过重新排列其字母使回文字符串成为非回文字符串

标签 c++ algorithm

问:通过重新排列其字母使回文字符串成为非回文字符串。

我只想知道为什么我的解决方案在提交代码时对某些测试用例失败(错误答案)。我确定有一个简单的解决方案,例如对整个字符串进行排序?

void makeNonPalindrome(string& s)
{
    bool ans = false;
    int l = s.length();
    if(l % 2 == 0)
    {
        for(int i = l/2; i < l; i++)
        {
            if(s[l/2 - 1] != s[i])
            {
                swap(&s[l/2 - 1],&s[i]);
                ans = true;
                break;
            }

        }
        if(!ans)
        {
            for(int i = 0; i < l/2-1; i++)
            {
                if(s[l/2 - 1] != s[i])
                {
                    ans = true;
                    break;
                }
            }
        }
    }
    else
    {
        for(int i = l/2 + 1; i < l; i++)
        {
            if(s[l/2 - 1] != s[i])
            {
                swap(&s[l/2 - 1],&s[i]);
                ans = true;
                break;
            }

        }
        if(!ans)
        {
            for(int i = 0; i < l/2-1; i++)
            {
                if(s[l/2 - 1] != s[i])
                {
                    ans = true;
                    break;
                }
            }
        }
        if(!ans)
        {
            if(s[l/2] != s[0])
            {
                swap(&s[l/2],&s[0]);
                ans = true;
            }
        }
    }
    if(ans)
        cout << s << '\n';
    else
        cout << -1 << '\n';
}

最佳答案

重新排列回文使其成为非回文可以非常快地完成,只需尝试交换字符串中两个相邻的字母(如果它们不同)。
例如,在 'bob' 中,您需要找到第一个不同的相邻字母(在我们的例子中是 bo) , 并交换它们。结果将是 'obb',这不是回文。

void makeNonPalindrome(std::string& s) {
    char tmp;
    for (unsigned i = 0; i < s.length() - 1; i++) {
        if (s[i] != s[i+1]) {  // then swap s[i] and s[i+1]
            tmp = s[i];
            s[i] = s[i+1];
            s[i+1] = tmp;
            std::cout << s << '\n';
            return;
        }
    }
    std::cout << -1 << '\n';
}

这是使回文成为非回文的一种更简单的方法。 注意:此函数假定输入确实是一个回文,因此如果您向它输入一个类似 'oob' 的字符串,它将输出 'bob',这是一个回文。

关于c++ - 通过重新排列其字母使回文字符串成为非回文字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56000704/

相关文章:

regex - 将字符集转换为 nfa/dfa 的高效算法

java - LeetCode 中的递归和回溯是如何工作的?

algorithm - 如何实现混凝土红青浮雕眼镜显示器的红色和青色校准程序?

c++ - 在 C++ 中扩展 QML ApplicationWindow

c++ - 使用 MPI 的不平衡负载 (v2.0)

c++ - OpenCV 将加载图像但不显示它

c++ - 如何在我的系统中使用 OpenCL

c++ - 此示例的最佳字符串哈希函数

java - 仅当匹配阈值字节时才在映射中填充字符串值

c++ - 将 intptr_t 传递给需要 int 的函数是否安全?