問題描述解題思路:此題關鍵是要在測試字串s[i]中找到一段子串和對照字串tests相匹配,這裡將兩個要比較的字串上下排列,將待測試字串按每次乙個字元的移動速度向左邊移動,始終對照兩字串位置相對應的字元,若完全匹配,則表示命中,列印測試字串。拖動測試字串情形見下圖:給出乙個字串和多行文字,在這些文字中找到字串出現的那些行。你的程式還需支援大小寫敏感選項:當選項開啟時,表示同乙個字母的大寫和小寫看作不同的字元;當選項關閉時,表示同乙個字母的大寫和小寫看作相同的字元。
輸入格式
輸入的第一行包含乙個字串s,由大小寫英文本母組成。
第二行包含乙個數字,表示大小寫敏感的選項,當數字為0時表示大小寫不敏感,當數字為1時表示大小寫敏感。
第三行包含乙個整數n,表示給出的文字的行數。
接下來n行,每行包含乙個字串,字串由大小寫英文本母組成,不含空格和其他字元。
輸出格式
輸出多行,每行包含乙個字串,按出現的順序依次給出那些包含了字串s的行。
樣例輸入
hello15
helloworld
hihihellohihi
grepisagreattool
hello
helloisnothello
樣例輸出
helloworld
hihihellohihi
helloisnothello
樣例說明
在上面的樣例中,第四個字串雖然也是hello,但是大小寫不正確。如果將輸入的第二行改為0,則第四個字串應該輸出。
評測用例規模與約定
1<=n<=100,每個字串的長度不超過100。
另外對於題中「選項關閉」的情形,將對照字串和測試字串都一律轉換成大/小寫字母後,仍然按照上述步驟進行匹配就行。
**如下:
1 #include2 #include34char s[101][101];5
6int
main()730
}31}32
else
if(flag==0);//
儲存轉化後的測試字串陣列
34char tests1[101] = ;//
儲存轉化後的對照字串
35for(k= 0;k <= len ; k++)
3641
for(k= 0;k <= strlen(s[i]) ; k++)
4247
for(k = 0;k <= strlen(s[i]) ; k++)//
這段**和上面重複,注意比較的是轉化後的字串,輸出的是原字串
4857}58
}59}60
return0;
61 }
ccf 201409 3 字串匹配
問題描述 給出乙個字串和多行文字,在這些文字中找到字串出現的那些行。你的程式還需支援大小寫敏感選項 當選項開啟時,表示同乙個字母的大寫和小寫看作不同的字元 當選項關閉時,表示同乙個字母的大寫和小寫看作相同的字元。輸入格式 輸入的第一行包含乙個字串s,由大小寫英文本母組成。第二行包含乙個數字,表示大小...
CCF 201409 3 字串匹配
試題編號 201409 3 試題名稱 字串匹配 時間限制 1.0s 記憶體限制 256.0mb 問題描述 問題描述 給出乙個字串和多行文字,在這些文字中找到字串出現的那些行。你的程式還需支援大小寫敏感選項 當選項開啟時,表示同乙個字母的大寫和小寫看作不同的字元 當選項關閉時,表示同乙個字母的大寫和小...
ccf 201409 3 字串匹配
試題編號 201409 3 試題名稱 字串匹配 時間限制 1.0s 記憶體限制 256.0mb 問題描述 給出乙個字串和多行文字,在這些文字中找到字串出現的那些行。你的程式還需支援大小寫敏感選項 當選項開啟時,表示同乙個字母的大寫和小寫看作不同的字元 當選項關閉時,表示同乙個字母的大寫和小寫看作相同...