C/C++算法入门 | 字符串处理

不爱生姜不吃醋⭐️

如果本文有什么错误的话欢迎在评论区中指正

与其明天开始,不如现在行动!

文章目录


🌴前言

字符串处理题在考试中十分常见,也是能很好体现代码能力的一种题型。对于这种题型,一般需要仔细分析清楚题目的输入输出格式才能顺利解决题目。在有些题目中,可能实现逻辑会非常麻烦,而且可能会有很多细节和边界情况。因此对代码能力较弱的考生是不利的。此类题目需要多做多想,积累经验。


🌴回文串

1.题目(codeup 5901)

题目描述

读入一串字符,判断是否是"回文串"。"回文串"是一个正读和反读都一样的字符串,比如"level"或者"noon"就是回文串

输入格式

一行字符串,长度不超过255

输出格式

如果是"回文串",输出"YES",否则输出"NO"

输入样例

12321

输出样例

YES

2.思路

  1. 遍历字符串的前一半
  2. 用前一半和后一半对比
  3. 只要有一个位置不对,那就不是"回文串"
  4. 遍历结束输出结果

3.代码实现

c 复制代码
#include <cstdio>
#include <cstring>

bool judge(int x, int y, char c[]){
    for (int i = x; i >= 0; i--)
    {
        if(c[x] != c[y]) return false;
        x--;
        y++;
    }
    return true;
}

int main() {
    char c[255];
    scanf("%s", c);
    int x = strlen(c) / 2 - 1;
    int y = strlen(c) - x - 1;
    if(judge(x, y, c)) printf("YES");
    else printf("NO");

    return 0;
}

🌴总结

文章中代码的编写使用的都是C/C++基础知识,多加练习熟能生巧。

本文中若是有出现的错误请在评论区或者私信指出,我再进行改正优化,如果文章对你有所帮助,请给博主一个宝贵的三连,感谢大家😘!!!


相关推荐
郝学胜-神的一滴25 分钟前
完全二叉树与堆底层原理深度剖析 | 手写C++大顶堆实现
java·开发语言·数据结构·c++·python·算法
青山木27 分钟前
Hot 100 --- 缺失的第一个正数
算法·leetcode·哈希算法
农民小飞侠28 分钟前
[leetcode] 165. Compare Version Numbers
java·算法·leetcode
装不满的克莱因瓶39 分钟前
掌握语义分割经典模型 FCN——从像素分类到端到端分割的奠基之作
人工智能·python·深度学习·算法·机器学习·分类·数据挖掘
学计算机的计算基44 分钟前
链表算法上篇:LeetCode 206/234/141/142/160/21 题解与易错点
java·笔记·算法·链表
大白话_NOI1 小时前
【洛谷 P2678】 [NOIP2015 提高组] 跳石头 超详细题解
c++·算法
xwz小王子1 小时前
ICRA 2026深度观察:全栈闭环成标配,中国具身智能势力显著崛起
大数据·人工智能·算法
孬甭_1 小时前
深入解析归并排序:稳定高效的分治典范
算法·排序算法
DXM05211 小时前
第14期|高阶分割模型:Transformer/SegFormer遥感应用
人工智能·python·神经网络·算法·计算机视觉·cnn·ageo