回文字符串

简介: 回文字符串就是正读反读都一样的字符串,比如,“level”和“noon”都是回文字符串。要求从键盘中输入一行字符串,并判断此字符串是否为回文字符串。

1.题目
回文字符串就是正读反读都一样的字符串,比如,“level”和“noon”都是回文字符串。要求从键盘中输入一行字符串,并判断此字符串是否为回文字符串。

2.补充知识点
gets()
括号里加字符数组名,输入的字符串存入该字符数组里,与getchar()差不多,只不过getchar()是从缓冲区中读取一个字符,而gets()是从输入缓冲区中读取一个字符串

puts()
向标准输出设备屏幕输出字符串并换行

string.h
与math.h一样也是库函数头文件,string.h是字符串的库函数头文件,调用字符串函数需要声明string.h

strlen()
求字符串即字符数组的长度,需要注意的是strlen()求得的值比字符数组最后一个元素的下标大1,比如:char a[6]={"china"};strlen(a)的值为5而数组a的最后一个元素'a'的下标为4,所以当我们想使用for循环输出数组a的时候应该是for(int i=0;i<strlen(a)-1;i++)

3.思路
先定义一个字符数组用来装字符串,在定义一个flag来判断字符串中是否为回文字符,用gets()获得字符串,把flag赋值为1,for循环从0开始到字符数组的一半结束,逐个判断字符是否相等,如果有不相等则flag=0,循环结束后判断flag为1还是为0,如果flag为1则输出该字符串是回文字符串,反之flag为0输出该字符串不是回文字符串。

4.代码

#include "stdio.h"
#include "string.h"
 
int main(void) {
    char s[20];
    int flag, n;
    printf("请输入字符串:");
    gets(s);
    flag = 1;
    n = strlen(s) / 2;
 
    for (int i = 0; i < n; i++) {
        if (s[i] != s[strlen(s) - 1 - i]) {
            flag = 0;
            break;
        }
    }
 
    if (flag == 1) {
        printf("%s是回文字符串\n", s);
    }
 
    else if (flag == 0) {
        printf("%s不是回文字符串\n", s);
    }
 
    return 0;
}

5.执行结果

image.png

相关文章
|
8月前
|
机器学习/深度学习 测试技术 Windows
【动态规划】【回文】【字符串】1147. 段式回文
【动态规划】【回文】【字符串】1147. 段式回文
|
Python
Python函数isdigit()--判断字符串是否为数字
Python函数isdigit()--判断字符串是否为数字
222 0
|
2月前
|
Python
递归魔法:判断字符串是否为回文
本文介绍了如何使用递归判断一个字符串是否是回文。回文字符串是指正读和反读都相同的字符串。文章详细讲解了递归的基本思想和Python实现,并通过多个示例验证了函数的正确性。递归方法通过将大问题分解成更小的子问题,使得判断回文变得简单高效。
71 5
|
7月前
字符串\判断回文
字符串\判断回文
32 2
字符串的全排列
字符串的全排列
89 0
|
算法 前端开发 API
字符串看到 ”回文“ 尝试双指针
字符串看到 ”回文“ 尝试双指针
67 0
|
机器学习/深度学习 NoSQL 算法
字符串——344.反转字符串
本专栏按照数组—链表—哈希—字符串—栈与队列—二叉树—回溯—贪心—动态规划—单调栈的顺序刷题,采用代码随想录所给的刷题顺序,一个正确的刷题顺序对算法学习是非常重要的,希望对大家有帮助
字符串——344.反转字符串
回文串
题目描述: 回文串是从左到右或者从右到左读起来都一样的字符串,试编程判别一个字符串是否为回文串。
135 0
031.判断字符串是否回文
031.判断字符串是否回文
98 0