判断是否是回文串(Valid Palindrome)

本文介绍了一种用于判断给定字符串是否为回文串的算法实现,该算法通过左右双指针从两端向内扫描,同时使用isalnum()和tolower()函数过滤并统一字母大小写。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述:

判断一个字符串是否是回文串。

注意只有大小写字母和数字才算是串的内容,其他字符都跳过。


思路:左右两个指针逐渐往中间逼近就可以了。

isalnum()函数是判断是否是字母数字的,其他字符跳过;tolower()函数是将字母数字都转换成小写进行判断。


算法实现:

class Solution{
public:
    bool isPalindrome(string s){
        int len=s.length(),l=0,r=len-1;
        while(l<r){
            if(!isalnum(s[l])) l++;
            else if(!isalnum(s[r])) r--;
            else if(tolower(s[l])==tolower(s[r])) {l++;r--;}
            else return false;
        }
        return true;
    }
};

### 判断回文字符串的 C 语言实现 在 C 语言中,可以通过多种方法来判断一个字符串是否为回文。以下是基于双指针法的一种常见实现方式[^3]。 #### 方法描述 此方法的核心思想是使用两个指针分别指向字符串的起始位置和末尾位置,逐步向中心移动并逐一比较对应的字符。如果在整个过程中发现任何一对字符不同,则可以断定该字符串不是回文;反之,若所有对应字符均相同,则说明它是回文。 下面是具体的代码实现: ```c #include <stdio.h> #include <string.h> #include <ctype.h> // 辅助函数:用于判断某个字符是否为字母或数字 int is_valid_char(char c) { return isalnum(c); } // 主要逻辑:判断字符串是否为回文 int is_palindrome(const char *str) { int start = 0; int end = strlen(str) - 1; while (start < end) { // 跳过非字母数字字符 while (start < end && !is_valid_char(str[start])) { start++; } while (start < end && !is_valid_char(str[end])) { end--; } // 比较当前有效字符(忽略大小写) if (tolower(str[start]) != tolower(str[end])) { return 0; // 不匹配即返回false } // 移动指针继续下一轮比较 start++; end--; } return 1; // 所有字符均匹配成功 } int main() { char input[100]; printf("请输入一个字符串: "); fgets(input, sizeof(input), stdin); // 去掉可能存在的换行符 size_t len = strlen(input); if (len > 0 && input[len - 1] == '\n') { input[len - 1] = '\0'; } if (is_palindrome(input)) { printf("该字符串是回文。\n"); } else { printf("该字符串不是回文。\n"); } return 0; } ``` 上述代码实现了以下几个功能: 1. **跳过无关字符**:通过 `is_valid_char` 函数过滤掉了非字母数字字符。 2. **忽略大小写**:利用标准库中的 `tolower` 函数统一转换为小写字母后再进行比较。 3. **边界条件处理**:当输入为空串或者单个字符时,默认视为回文[^4]。 #### 测试案例 为了验证程序的功能,可尝试以下测试数据: - 输入 `"A man, a plan, a canal: Panama"` 应输出 “该字符串是回文。” - 输入 `"hello world"` 应输出 “该字符串不是回文。” ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值