本题要求实现一个函数,对给定的一个字符串和两个字符,打印出给定字符串中从与第一个字符匹配的位置开始到与第二个字符匹配的位置之间的所有字符。
函数接口定义:
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 ) {
int i = 0, len = strlen(s);
char *rtn; //定义最后要返回的指针
for (; i < len&& s[i] != ch1; i++); //注意后面的分号,这是一个空
//循环,当i累加到s[i] == ch1时退出循环
rtn = &s[i]; //此时将s[i]也即首次出现ch1的地址赋值给rtn
for (; i < len; i++){ //从首次出现的这个字母开始打印,下标最大限度小于s的长度
printf("%c", s[i]);
if ( s[i] == ch2) //若累加i时遇到s[i] == ch2,则退出循环
break;
}
printf("\n");
return rtn;
}