本题要求实现一个函数,对给定的一个字符串和两个字符,打印出给定字符串中从与第一个字符匹配的位置开始到与第二个字符匹配的位置之间的所有字符。
函数接口定义:
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,j=0;
char p[1000];
char *a;
while(*(s+i)!=ch1&&*(s+i)!='\0'){//判断第一个位置,还有是否有可能是不存在开始符。
i++;
}a=s+i;//判断到的第1个字符的地址赋值给a,
p[j]=*(s+i);
i++;
j++;
while(*(s+i)!=ch2&&*(s+i)!='\0'){//第二次判断,判断是否又结束符
p[j]=*(s+i);//没有则开始一一赋值,
i++;
j++;
}
p[j]=*(s+i);
p[j+1]='\0';//这里是防止到ch2停止时,无法再赋值一个'\0'结束,否则可能会打印出其他东西。
printf("%s\n",p);
return a;//返回地址。
}