问:通过重新排列其字母使回文字符串成为非回文字符串。
我只想知道为什么我的解决方案在提交代码时对某些测试用例失败(错误答案)。我确定有一个简单的解决方案,例如对整个字符串进行排序?
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'
中,您需要找到第一个不同的相邻字母(在我们的例子中是 b
和 o
) , 并交换它们。结果将是 '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/