算法核心思想,忽略大小写
温馨提示:
你可以使用 strncasecmp 噢
没必要先全部转大写小写,费力不讨好
算法
static bool CmpNoCaseStr(const char *str1, const char *str2)
{
if (str1 && str2)
{
int strlen1 = strlen(str1); // 注意是 strlen 不是 sizeof。 指针,指针,指针
int strlen2 = strlen(str2);
if (strlen1 != strlen2)
{
return false; // 长度不等还有必要比较?
}
else {
int i = 0;
char ch1, ch2;
while ((ch1 = str1[i]) != '\0' && (ch2 = str2[i]) != '\0')
{
if (tolower(ch1) != tolower(ch2)) // 你也可以 toupper 啊
{
return false; // 某处不相等了? 结束比较吧
}
i++;
}
}
}
else {
return false;
}
return true;
}