回文字符串

简介: 回文字符串就是正读反读都一样的字符串,比如,“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. 段式回文
|
2月前
|
机器学习/深度学习 存储 JavaScript
最长回文子串
给定字符串s,寻找其中最长的回文子串。通过动态规划解决,使用二维数组dp记录子串是否为回文,状态转移方程基于子串两端字符相同及内部子串是否回文。初始条件为单字符和双字符子串的判断。时间复杂度和空间复杂度均为O(n^2)。
35 1
|
7月前
|
Java
5.最长回文子串
5.最长回文子串
|
8月前
|
Python
ptthon字符串的逆序输出
字符串的逆序输出
47 0
字符串的全排列
字符串的全排列
89 0
【leedcode】0005. 最长回文子串
【leedcode】0005. 最长回文子串
47 0
|
算法 前端开发 API
字符串看到 ”回文“ 尝试双指针
字符串看到 ”回文“ 尝试双指针
68 0
回文串
题目描述: 回文串是从左到右或者从右到左读起来都一样的字符串,试编程判别一个字符串是否为回文串。
136 0
Day8——反转字符串、反转字符串||、替换空格、反转字符串里的单词、左旋字符串
Day8——反转字符串、反转字符串||、替换空格、反转字符串里的单词、左旋字符串
109 0

热门文章

最新文章

下一篇
开通oss服务