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 以內。

方法1

解題思路:

本題要求我們驗證兩個字符串之間的子串關系。我們可以使用字符串的 find 函數來判斷一個字符串是否為另一個字符串的子串。find 函數會返回子串在主串中第一次出現的位置,如果找不到子串,則返回一個特殊值 string::npos

具體步驟如下:

  1. 讀取兩個字符串 s 1 s_1 s1? s 2 s_2 s2?
  2. 使用 find 函數判斷 s 1 s_1 s1? 是否為 s 2 s_2 s2? 的子串:
    • 如果 s2.find(s1) != string::npos,則 s 1 s_1 s1? s 2 s_2 s2? 的子串,輸出 (s1) is substring of (s2)
    • 否則,繼續下一步。
  3. 使用 find 函數判斷 s 2 s_2 s2? 是否為 s 1 s_1 s1? 的子串:
    • 如果 s1.find(s2) != string::npos,則 s 2 s_2 s2? s 1 s_1 s1? 的子串,輸出 (s2) is substring of (s1)
    • 否則,繼續下一步。
  4. 如果以上條件都不滿足,說明兩個字符串之間沒有子串關系,輸出 No substring

C++代碼實現:

#include <iostream>
#include <string>
using namespace std;int main() {string s1, s2;cin>>s1;cin>>s2;if (s2.find(s1) != string::npos) {cout << s1 << " is substring of " << s2 << endl;} else if (s1.find(s2) != string::npos) {cout << s2 << " is substring of " << s1 << endl;} else {cout << "No substring" << endl;}return 0;
}

代碼解釋:

  1. 使用 getline 函數讀取兩個字符串 s 1 s_1 s1? s 2 s_2 s2?,每個字符串占一行。
  2. 使用 s2.find(s1) != string::npos 判斷 s 1 s_1 s1? 是否為 s 2 s_2 s2? 的子串:
    • 如果條件成立,說明 s 1 s_1 s1? s 2 s_2 s2? 的子串,使用 cout 輸出 s1 is substring of s2
    • 否則,繼續下一步。
  3. 使用 s1.find(s2) != string::npos 判斷 s 2 s_2 s2? 是否為 s 1 s_1 s1? 的子串:
    • 如果條件成立,說明 s 2 s_2 s2? s 1 s_1 s1? 的子串,使用 cout 輸出 s2 is substring of s1
    • 否則,繼續下一步。
  4. 如果以上條件都不滿足,說明兩個字符串之間沒有子串關系,使用 cout 輸出 No substring

復雜度分析:

  • 時間復雜度: O ( n × m ) O(n \times m) O(n×m),其中 n n n m m m 分別是兩個字符串的長度。在最壞情況下,需要遍歷兩個字符串的所有可能的子串組合。
  • 空間復雜度: O ( 1 ) O(1) O(1)。只使用了常數級別的額外空間。

該解決方案利用了 find 函數快速判斷子串關系,避免了手動實現子串匹配的過程。通過兩次判斷,我們可以確定兩個字符串之間的子串關系,并輸出相應的結果。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/18233.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/18233.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/18233.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Python并發與異步編程

Python的并發與異步編程是兩個不同的概念&#xff0c;但它們經常一起使用&#xff0c;以提高程序的性能和響應能力。以下是對這兩個概念的詳細講解&#xff1a; 并發編程 (Concurrency) 并發編程是指在程序中同時執行多個任務的能力。Python提供了幾種實現并發的機制&#xff…

嵌入式進階——RTC時鐘

&#x1f3ac; 秋野醬&#xff1a;《個人主頁》 &#x1f525; 個人專欄:《Java專欄》《Python專欄》 ??心若有所向往,何懼道阻且長 文章目錄 RTC時鐘原理圖PCF8563寄存器控制與狀態寄存器 設備地址I2C環境初始化RTC寄存器數據讀取RTC寄存器數據寫入RTC鬧鐘設置RTC定時器設置…

2024.5.28晚訓題解

提前預告&#xff0c;市賽初中組會考算法題&#xff0c;應該會有兩道模板題 比如DFS BFS 二分 簡單動態規劃&#xff0c;雖然我們沒學多久&#xff0c;但是模板題你還是要會寫的 A題 編輯距離 動態規劃 注意多組輸入 #include<iostream> using namespace std; int dp[1…

9、C#【進階】特性

特性 文章目錄 1、特性概念2、自定義特性 Attribute3、特性的使用4、限制自定義特性的使用范圍5、系統自帶特性1、過時特性2、調用者信息特性3、條件編譯特性4、外部dll包函數特性 1、特性概念 特性是一種允許我們向程序的程序集添加元數據的語言結構 它是用于保存程序機構信息…

【機器學習300問】103、簡單的經典卷積神經網絡結構設計成什么樣?以LeNet-5為例說明。

一個簡單的經典CNN網絡結構由&#xff1a;輸入層、卷積層、池化層、全連接層和輸出層&#xff0c;這五種神經網絡層結構組成。它最最經典的實例是LeNet-5&#xff0c;它最早被設計用于手寫數字識別任務&#xff0c;包含兩個卷積層、兩個池化層、幾個全連接層&#xff0c;以及最…

ansible批量漏洞升級openssh版本

1、ansible宿主機準備好環境&#xff0c;并寫好hosts文件 [rootoxidized ansible]# cat hosts [all] 10.10.200.33 10.10.200.34 10.10.200.35跑playbook之前記得提前發送秘鑰 ssh-copy-id 10.10.200.33/34/352、下載好安裝包&#xff0c;然后編寫yml [rootoxidized ansible]…

【實用的 IDEA 配置和操作技巧總結】

前置知識 IDEA的設置快捷鍵為ctrlalts鍵&#xff0c;后文介紹IDEA常見的配置就不再贅述這一點了。 基礎配置 取消默認打開上次項目 日常開發都會打開不同的項目&#xff0c;初次安裝IDEA之后&#xff0c;每次打開IDEA都會開啟上一次啟動的項目&#xff0c;所以我們需要進入設…

0基礎學習Mybatis系列數據庫操作框架——Mysql的Geometry數據處理之WKB方案

大綱 序列化反序列化完整TypeHandlerSQL XML完整XML Mapper測試代碼代碼 在《0基礎學習Mybatis系列數據庫操作框架——Mysql的Geometry數據處理之WKT方案》中&#xff0c;我們介紹WTK方案的優點&#xff0c;也感受到它的繁瑣和缺陷。比如&#xff1a; 需要借助ST_GeomFromText…

element+ 引入圖標報錯 Failed to resolve import “@element-plus/icons-vue“ from “

element 引入圖標報錯 Internal server error: Failed to resolve import “element-plus/icons-vue” from “src\components\TimeLine.vue”. Does the file exist? 原因&#xff1a;element-plus需要單獨引入 icons 文檔 pnpm install element-plus/icons-vue之后就可以…

350種類型、10W+量級的API,企業應該怎么管?

忽如一夜春風來&#xff0c;萬物皆可API。 在互聯網時代&#xff0c;API無處不在&#xff1a;企業對外開放的數據、服務和業務能力&#xff0c;以API的形式提供給合作方&#xff1b;企業內部應用與應用、App與App之間的通信&#xff0c;通過API進行&#xff1b;甚至應用內部的…

php 連接sqlserver步驟

1.首先要確定使用的是sqlserver的哪個版本&#xff0c;比如sqlserver2012 2.確定服務器是64位還是32位的 3.確認一下使用php的哪個版本&#xff0c;比如php7.1 SQL Server 的 Microsoft PHP 驅動程序 Microsoft Drivers for PHP 支持矩陣 - PHP drivers for SQL Server | Mi…

Flutter 中的 CupertinoTabView 小部件:全面指南

Flutter 中的 CupertinoTabView 小部件&#xff1a;全面指南 在 Flutter 中&#xff0c;CupertinoTabView 是 Cupertino 組件庫中的一個 widget&#xff0c;它用于創建 iOS 風格的標簽頁視圖。這個 widget 通常與 CupertinoTabScaffold 結合使用&#xff0c;提供了一個底部帶有…

怎么做好客戶信息管理?

根據Forrester的調查表示&#xff0c;客戶滿意度的影響可能會使某些行業的收入每年增加高達 10 億美元。而提升客戶滿意度的關鍵環節便是做好客戶信息管理。但企業在進行客戶信息管理中往往會遇到以下問題&#xff1a; 客戶信息亂&#xff1a;客戶信息存在各個 Excel表格、個人…

PMP報考條件怎么查詢?如何判定自己是否符合條件?

PMP報考條件在PMI官網上就可以查詢&#xff0c;PMP報考條件只需要符合項目管理培訓經歷和項目管理經驗兩個方面的要求即可&#xff0c;大家可以對照下方的規定判斷自己是否符合PMP報名條件 PMP報考條件 以下是PMI&#xff08;中國&#xff09;官網對于PMP報名條件的規定&…

優秀的數據分析師需要具備哪些?

在數據驅動的時代&#xff0c;數據分析師的角色越來越被重視。本文將探討優秀數據分析師必備的三大核心能力&#xff0c;并通過實際案例說明如何將這些能力轉化為業務價值&#xff0c;幫助你在職業道路上更進一步。 在數字化迅速發展的今天&#xff0c;數據分析師扮演著極其重要…

ubuntu strace命令

strace 是 Linux 系統中的一個調試工具&#xff0c;用于跟蹤并記錄系統調用&#xff08;system calls&#xff09;和信號&#xff08;signals&#xff09;。在 Ubuntu 中&#xff0c;strace 命令可以幫助開發者和系統管理員了解一個程序在運行時如何與操作系統內核進行交互&…

TypeScript常見面試題第八節

題目三十六:什么是參數解構? 一、講解視頻 TS面試題三十六:什么是參數解構? 二、題目解析 本題目考察 ts 中的解構,解構是一種特殊語法,可以將對象解構到一個或多個局部變量中,可展開操作符相反,展開是允許將一個數組展開為另一個數組,或將一個對象展開為另一個對象,…

vue+antd實踐:在輸入框光標處插入內容

今天來看一個很簡單的需求。 需求描述&#xff1a;在輸入框光標處&#xff0c;插入指定的內容。 效果如下&#xff1a; 實現思路&#xff1a;剛開始還在想怎么獲取光標的位置&#xff0c;但是發現所做的項目是基于vue3antd組件&#xff0c;那么不簡單了嘛&#xff0c;只要調…

JAVA自制小游戲之推箱子

給家里孩子實現益智游戲開發,教會他怎么使用編程。以下是一個簡單的推箱子游戲的Java實現,包含兩個關卡: 這個程序包含兩個關卡,每個關卡都是一個字符串表示的地圖。游戲會提示玩家輸入移動方向(WASD),然后根據輸入的方向移動玩家。如果玩家成功將所有的箱子推到目標位…

配置物聯網平臺 保姆級教程

一、云平臺配置&#xff08;我們這里使用阿里云&#xff09; 1、注冊和登錄 &#xff08;1&#xff09;找到云平臺官網&#xff0c;點擊右上角的注冊登錄&#xff0c;完成之后&#xff0c;進行實名認證&#xff0c;任選一種認證方式。 ??????? 2、實例的開通和創建 …