C语言——oj刷题——回文字符串

简介: C语言——oj刷题——回文字符串

问题:


实现一个函数,判断一个字符串是否为回文字符串。


回文字符串是指正读和反读都相同的字符串。例如,"level"、"radar"和"madam"都是回文字符串。


要解决这个问题,我们可以使用两个指针分别指向字符串的首尾字符,然后逐步向中间移动,同时比较指针所指向的字符是否相等。如果在比较过程中发现不相等的字符,那么该字符串就不是回文字符串。


下面是一个示例代码,演示如何通过C语言实现判断回文字符串的函数:

#include <stdio.h>
#include <stdbool.h>
#include <string.h>
 
bool isPalindrome(const char *str) {
    int left = 0; // 左指针
    int right = strlen(str) - 1; // 右指针
 
    while (left < right) {
        if (str[left] != str[right]) {
            return false; // 如果字符不相等,则不是回文字符串
        }
        left++; // 左指针向右移动
        right--; // 右指针向左移动
    }
 
    return true; // 如果所有字符都相等,则是回文字符串
}
 
int main() {
    const char *str1 = "level";
    const char *str2 = "hello";
 
    if (isPalindrome(str1)) {
        printf("%s is a palindrome.\n", str1);
    } else {
        printf("%s is not a palindrome.\n", str1);
    }
 
    if (isPalindrome(str2)) {
        printf("%s is a palindrome.\n", str2);
    } else {
        printf("%s is not a palindrome.\n", str2);
    }
 
    return 0;
}

在上述代码中,isPalindrome函数接受一个指向常量字符的指针str作为参数,并返回一个布尔值。函数内部,我们使用left和right两个指针分别指向字符串的首尾字符。然后,通过一个循环,我们逐步将左指针向右移动,右指针向左移动,并比较指针所指向的字符是否相等。如果在比较过程中发现不相等的字符,那么该字符串就不是回文字符串,我们返回false。如果循环结束后没有发现不相等的字符,那么该字符串就是回文字符串,我们返回true。


在main函数中,我们定义了两个字符串str1和str2,并分别调用isPalindrome函数来判断它们是否为回文字符串。根据返回的结果,我们打印相应的提示信息。


这个算法的时间复杂度是O(n),其中n是字符串的长度。因为我们需要遍历字符串的一半来进行比较,所以算法的效率是非常高的。

相关文章
|
1月前
|
存储 C语言
【C语言】基础刷题训练4(含全面分析和代码改进示例)
【C语言】基础刷题训练4(含全面分析和代码改进示例)
|
1月前
|
C语言
【C语言刷题训练】——第7节(含代码与分析思路)
【C语言刷题训练】——第7节(含代码与分析思路)
|
1月前
|
测试技术 C语言 C++
【C语言刷题训练——6】鹏哥C语言刷题训练营笔记,含代码讲解改进
【C语言刷题训练——6】鹏哥C语言刷题训练营笔记,含代码讲解改进
|
1月前
|
存储 C语言
【C语言】鹏哥C语言刷题训练营——第5节内容笔记(含代码全面分析和改进,讲解)
【C语言】鹏哥C语言刷题训练营——第5节内容笔记(含代码全面分析和改进,讲解)
|
3月前
|
C语言
C语言刷题(函数)
C语言刷题(函数)
|
3月前
|
C语言
C语言刷题(数组)
C语言刷题(数组)
|
3月前
|
C语言
C语言刷题(循环结构程序设计)
C语言刷题(循环结构程序设计)
|
15天前
|
存储 Serverless C语言
【C语言基础考研向】11 gets函数与puts函数及str系列字符串操作函数
本文介绍了C语言中的`gets`和`puts`函数,`gets`用于从标准输入读取字符串直至换行符,并自动添加字符串结束标志`\0`。`puts`则用于向标准输出打印字符串并自动换行。此外,文章还详细讲解了`str`系列字符串操作函数,包括统计字符串长度的`strlen`、复制字符串的`strcpy`、比较字符串的`strcmp`以及拼接字符串的`strcat`。通过示例代码展示了这些函数的具体应用及注意事项。
|
18天前
|
存储 C语言
C语言程序设计核心详解 第十章:位运算和c语言文件操作详解_文件操作函数
本文详细介绍了C语言中的位运算和文件操作。位运算包括按位与、或、异或、取反、左移和右移等六种运算符及其复合赋值运算符,每种运算符的功能和应用场景都有具体说明。文件操作部分则涵盖了文件的概念、分类、文件类型指针、文件的打开与关闭、读写操作及当前读写位置的调整等内容,提供了丰富的示例帮助理解。通过对本文的学习,读者可以全面掌握C语言中的位运算和文件处理技术。
|
18天前
|
存储 C语言
C语言程序设计核心详解 第七章 函数和预编译命令
本章介绍C语言中的函数定义与使用,以及预编译命令。主要内容包括函数的定义格式、调用方式和示例分析。C程序结构分为`main()`单框架或多子函数框架。函数不能嵌套定义但可互相调用。变量具有类型、作用范围和存储类别三种属性,其中作用范围分为局部和全局。预编译命令包括文件包含和宏定义,宏定义分为无参和带参两种形式。此外,还介绍了变量的存储类别及其特点。通过实例详细解析了函数调用过程及宏定义的应用。