字符串比较中的C++字符

C++ character in string comparision

本文关键字:C++ 字符 比较 字符串      更新时间:2023-10-16

我熟悉c++,但不知道如何比较来自相同或不同字符串的索引字符。这里有一个回文示例,它使用int并通过字符串流将其转换为字符串。

bool ispalindrome(int a) {
    stringstream stream;
    stream<<a;
    string str = stream.str();
    int length = str.length();
    int offset = length - 1;
    for (int i=0; i<=offset; i++ && offset--) {
        if (str[i] == str[i + offset]) {
            return false;
        }
        offset--;
    }
    return true;
}

由于某种原因,这总是被评估为false。我不认为null终止与此有关,因为它不是按长度报告的,所以我想我一定使用了错误的比较方法。我似乎找不到像strncmp这样只有单个字符的东西。

[编辑:固定标题]

我不知道你是怎么写那个循环的,但我很确定它应该是

for (int i=0; i<=offset; i++, offset--) {
    if (str[i] != str[offset]) {
        return false;
    }
}

您可以使用迭代器:

std::string::iterator start = str.begin();
std::string::reverse_iterator end = str.rbegin();
int halfWay = str.length() / 2;
for (int i = 0; i <= halfWay; i++, start++, end++)
{
    if (*start != *end)
        return false;
}
return true;

免责声明:未经测试,但我也不太擅长C++!

可能使用逗号、

for (int i=0; i<=offset; i++ ,offset--)

更平常吗?

否则,

if (str[i] == str[i + offset]) {

使用"!="会更好而不是"=="

但是,对于一个简单的样本,我看不出的"总是错误的"行为

int main() {
  for ( int i = 0; i < 1000; ++i )
  cout << i << " = " << ispalindrome(i) << endl;
}

您的检查条件应该是:

    if (str[i] != str[i + offset]) {
               ^--here

如果只是检查回文,也可以使用STL 中的reverse

#include <algorithm>
#include <string>
bool isPalinDrome = false;
std::string mystr = "cnc";
std::string mystrcpy = mystr;
std::reverse(mystrcpy.begin(),mystrcpy.end());
if(mystr == mystrcpy)
isPalindrome =  true;

但如果你只是在比较各个角色,那么上面的答案已经告诉你如何去做了。因此,重申一下,您只需要遍历字符串的一半即可。