找出所有与字符串匹配的行
#include <stdio.h>
#define MAXLINE 1000 /* 最大输入行长度 */
int getline(char line[], int max);
int strindex(char source[], char searchfor[]);
char pattern[] = "ould"; /* 待查找的字符串 */
/* 找出所有与字符串匹配的行 */
main()
{
char line[MAXLINE];
int found = 0;
while(getline(line, MAXLINE) > 0)
if(strindex(line, pattern) >= 0){
printf("%s", line);
found++;
}
return found;
}
/* getline函数:将行保存到s中,并返回该行的长度 */
int getline(char s[], int lim)
{
int c, i;
i = 0;
while(--lim > 0 && (c=getchar()) != EOF && c != '\n')
s[i++] = c;
if(c == '\n')
s[i++] = c;
s[i] = '\0';
return i;
}
/* strindex函数:返回t在s中的位置,若未找到则返回-1 */
int strindex(char s[], char t[])
{
int i, j, k;
for(i = 0; s[i] != '\0'; i++){
for(j=i,k=0; t[k]!='\0' && s[j]==t[k]; j++, k++)
;
if(k > 0 && t[k] == '\0')
return i;
}
return -1;
}
1万+

被折叠的 条评论
为什么被折叠?



