CCF 201409 3(字串匹配)

2021-10-04 20:40:00 字數 1639 閱讀 8447

一:問題

1.問題描述

給出乙個字串和多行文字,在這些文字中找到字串出現的那些行。你的程式還需支援大小寫敏感選項:當選項開啟時,表示同乙個字母的大寫和小寫看作不同的字元;當選項關閉時,表示同乙個字母的大寫和小寫看作相同的字元。

2.格式

輸入格式

輸入的第一行包含乙個字串s,由大小寫英文本母組成。

第二行包含乙個數字,表示大小寫敏感的選項,當數字為0時表示大小寫不敏感,當數字為1時表示大小寫敏感。

第三行包含乙個整數n,表示給出的文字的行數。

接下來n行,每行包含乙個字串,字串由大小寫英文本母組成,不含空格和其他字元。

輸出格式

輸出多行,每行包含乙個字串,按出現的順序依次給出那些包含了字串s的行。

3.樣例

樣例輸入

hello15

helloworld

hihihellohihi

grepisagreattool

hello

helloisnothello

樣例輸出

helloworld

hihihellohihi

helloisnothello

樣例說明

在上面的樣例中,第四個字串雖然也是hello,但是大小寫不正確。如果將輸入的第二行改為0,則第四個字串應該輸出。

4.評測用例規模與約定

1<=n<=100,每個字串的長度不超過100。

二:理解

題意理解:

就是給乙個模式串,找一下,下面的n個串裡是否含有模式串,

不過有兩種情況:一種是不區分大小寫,另外一種就是不區分大小寫。

**理解:

區分大小寫的直接用find()函式查詢即可。

if

(strings.

find

(pattern)

!= strings.npos)

cout << strings << endl;

不區分大小要先將模式串與給的子串都轉化為一種狀態(都是大寫,或者都是小寫)。

然後直接查詢即可。

void

mystrlwr

(string &strings)

}mystrlwr

(pattern)

;string temp = strings;

mystrlwr

(temp);if

(temp.

find

(pattern)

!= temp.npos)

cout << strings << endl;

三:**

//201409-3

#include

#include

using

namespace std;

void

mystrlwr

(string &strings)

}int

main()

else

}return0;

}

ccf 201409 3 字串匹配

問題描述 給出乙個字串和多行文字,在這些文字中找到字串出現的那些行。你的程式還需支援大小寫敏感選項 當選項開啟時,表示同乙個字母的大寫和小寫看作不同的字元 當選項關閉時,表示同乙個字母的大寫和小寫看作相同的字元。輸入格式 輸入的第一行包含乙個字串s,由大小寫英文本母組成。第二行包含乙個數字,表示大小...

CCF 201409 3 字串匹配

試題編號 201409 3 試題名稱 字串匹配 時間限制 1.0s 記憶體限制 256.0mb 問題描述 問題描述 給出乙個字串和多行文字,在這些文字中找到字串出現的那些行。你的程式還需支援大小寫敏感選項 當選項開啟時,表示同乙個字母的大寫和小寫看作不同的字元 當選項關閉時,表示同乙個字母的大寫和小...

ccf 201409 3 字串匹配

試題編號 201409 3 試題名稱 字串匹配 時間限制 1.0s 記憶體限制 256.0mb 問題描述 給出乙個字串和多行文字,在這些文字中找到字串出現的那些行。你的程式還需支援大小寫敏感選項 當選項開啟時,表示同乙個字母的大寫和小寫看作不同的字元 當選項關閉時,表示同乙個字母的大寫和小寫看作相同...