一:問題
1.問題描述
給出乙個字串和多行文字,在這些文字中找到字串出現的那些行。你的程式還需支援大小寫敏感選項:當選項開啟時,表示同乙個字母的大寫和小寫看作不同的字元;當選項關閉時,表示同乙個字母的大寫和小寫看作相同的字元。2.格式
輸入格式3.樣例輸入的第一行包含乙個字串s,由大小寫英文本母組成。
第二行包含乙個數字,表示大小寫敏感的選項,當數字為0時表示大小寫不敏感,當數字為1時表示大小寫敏感。
第三行包含乙個整數n,表示給出的文字的行數。
接下來n行,每行包含乙個字串,字串由大小寫英文本母組成,不含空格和其他字元。
輸出格式
輸出多行,每行包含乙個字串,按出現的順序依次給出那些包含了字串s的行。
樣例輸入4.評測用例規模與約定hello15
helloworld
hihihellohihi
grepisagreattool
hello
helloisnothello
樣例輸出
helloworld
hihihellohihi
helloisnothello
樣例說明
在上面的樣例中,第四個字串雖然也是hello,但是大小寫不正確。如果將輸入的第二行改為0,則第四個字串應該輸出。
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 問題描述 給出乙個字串和多行文字,在這些文字中找到字串出現的那些行。你的程式還需支援大小寫敏感選項 當選項開啟時,表示同乙個字母的大寫和小寫看作不同的字元 當選項關閉時,表示同乙個字母的大寫和小寫看作相同...