本题要求实现一个函数,对给定的一个字符串和两个字符,打印出给定字符串中从与第一个字符匹配的位置开始到与第二个字符匹配的位置之间的所有字符。
函数接口定义:
char *match( char *s, char ch1, char ch2 );
函数
match
应打印s
中从ch1
到ch2
之间的所有字符,并且返回ch1
的地址。裁判测试程序样例:
#include <stdio.h> #define MAXS 10 char *match( char *s, char ch1, char ch2 ); int main() { char str[MAXS], ch_start, ch_end, *p; scanf("%s\n", str); scanf("%c %c", &ch_start, &ch_end); p = match(str, ch_start, ch_end); printf("%s\n", p); return 0; } /* 你的代码将被嵌在这里 */
输入样例1:
program r g
结尾无空行
输出样例1:
rog rogram
结尾无空行
输入样例2:
program z o
输出样例2:
(空行) (空行)
输入样例3:
program g z
输出样例3:
gram gram
char *match( char *s, char ch1, char ch2 ){
char *p=s,*c=NULL;
while(ch1!=*p&&*p!='\0'){
p++;
}
if(*p!='\0'){
c=p;
while(ch2!=*p&&*p!='\0'){
putchar(*p);
p++;
}
if(*p!='\0'){
putchar(*p);
printf("\n");
return c;
}else{
printf("\n");
return c;
}
}else{
printf("\n");
return p;
}
}