中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

使用C語言編寫高效的回文字符串識別程序

小樊
87
2024-04-26 16:55:52
欄目: 編程語言

#include <stdio.h>
#include <string.h>
#include <ctype.h>

int isPalindrome(char *str) {
    int len = strlen(str);
    int i, j;

    for (i = 0, j = len - 1; i < j; i++, j--) {
        while (!isalnum(str[i]) && i < j) {
            i++;
        }
        while (!isalnum(str[j]) && i < j) {
            j--;
        }

        if (tolower(str[i]) != tolower(str[j])) {
            return 0;
        }
    }

    return 1;
}

int main() {
    char str[100];

    printf("Enter a string: ");
    fgets(str, sizeof(str), stdin);
    str[strcspn(str, "\n")] = '\0';

    if (isPalindrome(str)) {
        printf("The string is a palindrome.\n");
    } else {
        printf("The string is not a palindrome.\n");
    }

    return 0;
}

這個程序首先定義了一個用于判斷一個字符串是否回文的函數isPalindrome。在這個函數中,使用了兩個指針i和j分別指向字符串的開頭和結尾,然后循環比較兩個指針指向的字符是否相同,如果不同則返回0,表示不是回文。在比較之前,還會檢查字符是否是字母或數字,忽略其他字符。

main函數中,首先獲取用戶輸入的字符串,然后調用isPalindrome函數判斷是否為回文字符串,并輸出結果。

0
余姚市| 丹棱县| 左贡县| 芒康县| 盐亭县| 高台县| 新干县| 乌鲁木齐市| 顺昌县| 融水| 新泰市| 中西区| 湖州市| 彰化县| 衡南县| 波密县| 黄骅市| 九江县| 永平县| 酉阳| 台中县| 温泉县| 汉沽区| 虎林市| 德清县| 扎鲁特旗| 兴海县| 仲巴县| 西畴县| 铜梁县| 灵山县| 睢宁县| 甘泉县| 永新县| 林周县| 永泰县| 昌吉市| 临湘市| 额敏县| 乌拉特前旗| 民勤县|