[特殊字符] 2025蓝桥杯备赛Day8——B2118 验证子串

🔍 2025蓝桥杯备赛Day8——B2118 验证子串

🚀 题目速览

题目难度:⭐️ 适合掌握字符串基本操作

考察重点:子串判断、字符串查找、条件分支处理

B2118 验证子串

题目描述

输入两个字符串,验证其中一个串是否为另一个串的子串。

输入格式

两行,每行一个字符串。

输出格式

若第一个串 s 1 s_1 s1 是第二个串 s 2 s_2 s2 的子串,则输出(s1) is substring of (s2)

否则,若第二个串 s 2 s_2 s2 是第一个串 s 1 s_1 s1 的子串,输出(s2) is substring of (s1)

否则,输出 No substring

输入输出样例 #1

输入 #1

abc
dddncabca

输出 #1

abc is substring of dddncabca

输入输出样例 #2

输入 #2

aaa
bbb

输出 #2

No substring

说明/提示

对于 100 % 100 \% 100% 的数据,字符串长度在 20 20 20 以内。

🔥 解法一:直接查找法(推荐)

🛠️ 实现思路

核心技巧:利用 string::find 函数进行子串判断

算法优势:代码简洁,时间复杂度 O(n*m)(n和m为字符串长度)

#include <iostream>
#include <string>
using namespace std;int main() {string s1, s2;getline(cin, s1);  // 读取第一个字符串(兼容含空格输入)getline(cin, s2);  // 读取第二个字符串// 核心判断逻辑(利用string::find)if (s2.find(s1) != string::npos) {  // 判断s1是否在s2中cout << s1 << " is substring of " << s2 << endl;} else if (s1.find(s2) != string::npos) {  // 判断s2是否在s1中cout << s2 << " is substring of " << s1 << endl;} else {cout << "No substring" << endl;  // 无包含关系}return 0;
}

🔥 解法二:双检暴力匹配法

🛠️ 实现思路

核心技巧:手动实现子串匹配逻辑,加深算法理解

教学价值:理解字符串匹配底层原理

#include <iostream>
#include <string>
using namespace std;// 自定义子串判断函数(暴力匹配)
bool isSubstring(const string& mainStr, const string& subStr) {if (subStr.empty()) return true;  // 空串是任意字符串的子串if (mainStr.size() < subStr.size()) return false;  // 主串更短时直接返回// 双重循环逐字符匹配for (int i = 0; i <= mainStr.size() - subStr.size(); ++i) {  // 主串起始位置遍历bool match = true;for (int j = 0; j < subStr.size(); ++j) {  // 子串逐字符比对if (mainStr[i + j] != subStr[j]) {  // 发现不匹配字符match = false;break;  // 提前结束内层循环}}if (match) return true;  // 完全匹配时返回成功}return false;  // 遍历结束未找到匹配
}int main() {string s1, s2;getline(cin, s1);getline(cin, s2);// 分支判断逻辑if (isSubstring(s2, s1)) {  // 先判断s1是否是s2的子串cout << s1 << " is substring of " << s2 << endl;} else if (isSubstring(s1, s2)) {  // 再判断s2是否是s1的子串cout << s2 << " is substring of " << s1 << endl;} else {cout << "No substring" << endl;  // 双重判断失败}return 0;
}

📚 知识点总结

一、关键库函数

  1. string::find()

    size_t pos = s.find(sub); // 返回sub首次出现的位置
    // 返回值说明:
    // - 找到:返回合法索引(0 ≤ pos < s.size())
    // - 未找到:返回string::npos(通常为-1)
    

二、暴力匹配算法

  1. 双循环结构

    for (主串遍历) {for (子串遍历) {逐字符比对}
    }
    
  2. 时间复杂度:O(n*m)(最坏情况)

三、string::npos 深度解析

特性说明
定义static const size_t npos = -1,本质是size_t类型的最大值(64位系统为18446744073709551615
用途表示字符串查找失败(如find()未匹配到子串),或表示“直到字符串末尾”的截取操作(如substr(pos, npos)
使用规范必须与size_t类型变量比较,避免与int混用导致的逻辑错误
典型错误if (s.find("x") == -1)(错误,应写为if (s.find("x") == string::npos)

🔥 双解法对比分析

维度直接查找法(解法一)双检暴力匹配法(解法二)
时间复杂度O(1)(哈希表查询)O(nm)(暴力匹配,实际效率低)
扩展性:仅需修改哈希表键值对即可支持新规则:需修改多个条件分支,易引入逻辑错误
可读性★★★★★:规则集中可视化,逻辑清晰★★★☆☆:分支嵌套复杂时需逐行推导逻辑
内存占用约30字节(存储哈希表)0额外内存:无数据结构存储开销
抗错能力:自动处理所有合法输入,未匹配时返回npos:依赖首字母正确性,非法输入易导致错误

🚨 常见错误警示

错误1:输入顺序颠倒

// 错误:先判断s1是否在s2中,但变量顺序颠倒
if (s1.find(s2) != npos) { ... } 
// 正确顺序应保持题目要求的判断顺序

错误2:空字符串处理

// 错误:未处理空字符串导致逻辑异常
if (s2.find(s1) != npos) // 若s1为空则恒成立
// 修正:题目保证输入非空(根据样例)

错误3:输出格式错误

// 错误:变量输出顺序颠倒
cout << s2 << "..." << s1; // 与题意要求不符

🌟 举一反三

变种题1:统计子串出现次数

int count = 0;
size_t pos = 0;
while ((pos = s.find(sub, pos)) != string::npos) {++count;pos += sub.size(); // 非重叠统计
}

变种题2:大小写不敏感判断

// 将字符串统一转为小写再比较
string lower_str = str;
transform(lower_str.begin(), lower_str.end(), lower_str.begin(), ::tolower);

🛠️ 实战技巧

1. 输入优化

// 使用快速IO(关闭同步流)
ios::sync_with_stdio(false);
cin.tie(nullptr);

2. 边界测试用例

测试案例预期输出测试目的
s1=“a”, s2=“a”a is substring of a完全相同字符串
s1=“ab”, s2=“abc”ab is substring of abc前部匹配
s1=“abc”, s2=“aababc”abc is substring of aababc后部匹配
s1=“abcd”, s2=“abc”abc is substring of abcd后判断成立

蓝桥杯考场策略

  • 优先使用解法一:代码简洁,不易出错
  • 注意输出格式:严格按照题目要求的字符串顺序输出
  • 极端情况测试:测试长度相差悬殊的字符串(如s1长度20,s2长度1)

👉 思考题:若要求判断是否是连续子序列(可不连续),如何修改代码?

答案提示:需使用双指针法遍历两个字符串。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/38035.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[极客大挑战 2019]BabySQL—3.20BUUCTF练习day4(3)

[极客大挑战 2019]BabySQL-3.20BUUCTF练习day4(3) 做题过程 打开是以下页面&#xff08;前几天有它的第一版和第二版出现&#xff09;输入1’ 回显以下内容&#xff08;还是字符型以单引号闭合&#xff0c;因为有报错信息回显&#xff09; 输入1 order by 4%23回显成这个 被过…

[Effective C++]条款20:宁以 pass-by-reference-to-const替换 pass-by-value

. 在C中&#xff0c;函数参数与返回值的数据传递的方式&#xff0c;对程序的性能和正确性有着重要影响。C默认使用pass-by-value&#xff08;传值&#xff09;的方式传递参数。但这种方式在某些情况下会导致性能问题和对象切割问题。 C推荐使用pass-by-reference-to-const&…

文字变央视级语音转换工具

大家在制作短视频、广告宣传、有声读物、自媒体配音、学习辅助等场景的时候&#xff0c;经常会需要用到配音来增强视频的表现力和吸引力。然而&#xff0c;市面上的一些配音软件往往需要收费&#xff0c;这对于很多初学者或者预算有限的朋友来说&#xff0c;无疑增加了一定的负…

邂逅书香:在诗韵与青春中找寻心灵归处

在信息如洪流般奔涌的当下&#xff0c;我们的灵魂时常在喧嚣中漂泊&#xff0c;渴望一处宁静港湾。而书籍&#xff0c;一直以来都是人类最忠诚的精神伴侣。今天&#xff0c;要为诗歌爱好者和青春文学迷们带来两份特别的礼物——《韵之队诗集》与《青春与爱共舞》&#xff0c;它…

国科大——计网(0812)——实验作业

**前沿&#xff1a;**此博客记录了24—25年度秋季学期计算机网络&#xff08;0812&#xff09;课程的实验作业&#xff0c;所提供的材料仅供参考。 0 实验题目 本次实验总共提供了四个可选的题目&#xff0c;即BGP分析实验&#xff0c;BGP 前缀劫持攻击及检测实验&#xff0c…

新能源汽车高压液体加热器总成技术解析及未来发展趋势

引言 新能源汽车的快速发展对热管理系统提出了更高要求&#xff0c;高压液体加热器作为核心组件&#xff0c;直接影响车辆低温性能、电池寿命及用户体验。本文以实际产品为例&#xff0c;结合行业数据与技术趋势&#xff0c;深度解析高压液体加热器的技术原理、市场现状及未来…

蓝桥杯 数字接龙

问题描述 小蓝最近迷上了一款名为《数字接龙》的迷宫游戏。 游戏在一个大小为 N N 的格子棋盘上展开&#xff0c;其中每一个格子处都有一个 0 到 K-1 之间的整数。 游戏规则如下&#xff1a; 从左上角 (0, 0) 出发&#xff0c;目标是到达右下角 (N-1, N-1)。 每一步可以选…

SysVinit和Systemd的系统运行级别

Linux运行级别 SysVinit系统(init守护进程)Linux系统运行级别SysVinit系统(init守护进程)查看Linux运行级别SysVinit系统(init守护进程)修改运行级别&#xff1a; Systemd守护进程Linux系统运行级别systemd查看运行级别Systemd查看系统当前运行级别 systemd修改运行级别multi-u…

SAP SD学习笔记33 - 预詑品(寄售物料),预詑品引渡(KB),预詑品出库(KE)

上一章讲了Service品目。 SAP SD学习笔记32 - Service品目(服务产品&#xff09;-CSDN博客 本章继续讲SAP SD的知识 - 预詑品(寄售物料)。 目录 1&#xff0c;预詑品概要 1-1&#xff0c;预詑品(寄售物料)的概念 1-2&#xff0c;预詑品的4种业务 1-3&#xff0c;受托品与…

DeiT:数据高效的图像Transformer及其工作原理详解

DeiT&#xff1a;数据高效的图像Transformer及其工作原理详解 随着Transformer架构在自然语言处理&#xff08;NLP&#xff09;领域的巨大成功&#xff0c;研究者们开始探索其在计算机视觉领域的应用。Vision Transformer&#xff08;ViT&#xff09;是最早将Transformer直接应…

【 <二> 丹方改良:Spring 时代的 JavaWeb】之 Spring Boot 中的异常处理:全局异常与自定义异常

<前文回顾> 点击此处查看 合集 https://blog.csdn.net/foyodesigner/category_12907601.html?fromshareblogcolumn&sharetypeblogcolumn&sharerId12907601&sharereferPC&sharesourceFoyoDesigner&sharefromfrom_link <今日更新> 一、开篇整…

【Mybatis-plus】在mybatis-plus中 if test标签如何判断 list不为空

博主介绍&#xff1a;✌全网粉丝22W&#xff0c;CSDN博客专家、Java领域优质创作者&#xff0c;掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围&#xff1a;SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物…

Lineageos 22.1(Android 15)制定应用强制横屏

一、前言 有时候需要系统的某个应用强制衡平显示&#xff0c;不管他是如何配置的。我们只需要简单的拿到top的Task下面的ActivityRecord&#xff0c;并判断包名来强制实现。 二、调整wms com.android.server.wm.DisplayRotation /*** Given an orientation constant, return…

HTML网页代码预览器

HTML网页代码预览器 可以用于学习和实验HTML和CSS&#xff0c;比较方便。源码参考自网络。 功能 实时预览&#xff1a;当你在左侧的“代码编辑器”中输入代码时&#xff0c;右侧的“预览窗口”会实时显示你的网页效果&#xff08;注意&#xff0c;不能体现嵌入的JavaScript运…

Arm Linux ceres库编译

由于工作需要&#xff0c;需在国产化系统上编译ceres库&#xff0c;手上有一块树莓派&#xff0c;就在树莓派上面进行测试编译ceres库&#xff0c;总体来说比较顺利。只出现了一点小问题 参考链接&#xff1a; Ceres中文教程-安装 按照上面Linux编译过程 目录 1、在线安装依赖…

【算法学习计划】动态规划 -- 背包问题(01背包和完全背包)

目录 DP41 【模板】01背包 leetcode 416.分割等和子集 leetcode 494.目标和 leetcode 1049.最后一块石头的重量Ⅱ DP42 【模板】完全背包 leetcode 322.零钱兑换 leetcode 518.零钱兑换Ⅱ leetcode 279.完全平方数 今天&#xff0c;我们将通过 8 道题目&#xff0c;来带…

138. 随机链表的复制

题目&#xff1a; 给你一个长度为 n 的链表&#xff0c;每个节点包含一个额外增加的随机指针 random &#xff0c;该指针可以指向链表中的任何节点或空节点。 构造这个链表的 深拷贝。 深拷贝应该正好由 n 个 全新 节点组成&#xff0c;其中每个新节点的值都设为其对应的原节…

网络HTTPS协议

Https HTTPS&#xff08;Hypertext Transfer Protocol Secure&#xff09;是 HTTP 协议的加密版本&#xff0c;它使用 SSL/TLS 协议来加密客户端和服务器之间的通信。具体来说&#xff1a; • 加密通信&#xff1a;在用户请求访问一个 HTTPS 网站时&#xff0c;客户端&#x…

19921 多重背包

19921 多重背包 ⭐️难度&#xff1a;中等 &#x1f31f;考点&#xff1a;动态规划、背包问题 &#x1f4d6; &#x1f4da; import java.util.Arrays; import java.util.LinkedList; import java.util.Queue; import java.util.Scanner;public class Main {static int N …

C/C++蓝桥杯算法真题打卡(Day5)

一、P8772 [蓝桥杯 2022 省 A] 求和 - 洛谷 算法代码&#xff1a; #include<bits/stdc.h> // 包含标准库中的所有头文件&#xff0c;方便编程 using namespace std; // 使用标准命名空间&#xff0c;避免每次调用标准库函数时都要加 std::int main() {int n; …