本题要求实现一个函数,对给定的一个字符串和两个字符,打印出给定字符串中从与第一个字符匹配的位置开始到与第二个字符匹配的位置之间的所有字符。
函数接口定义:
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
扩展部分
输入样例4:
program
g p
输出样例4:
(空行)
(空行)
我的代码
char *match( char *s, char ch1, char ch2 )
{
char *ch;
int i=MAXS+1,j=MAXS+1;/*用于记录匹配的位置,i->ch1,j->ch2*/
ch=s;
while(*ch!='\0')
{
if(*ch==ch1&&i==MAXS+1)i=ch-s;/*只记录第一次匹配的位置*/
if(*ch==ch2&&j==MAXS+1)j=ch-s;/*只记录第一次匹配的位置*/
ch++;
}
ch=s;
/*以下部分含扩展:如果第一个字符在后,第二个字符在前则返回0,不打印*/
while(*(ch++)!='\0')if(ch>=s+i&&ch<=s+j)printf("%c",*ch);
printf("\n");
return j>i?s+i:0;/*选择性返回,如果不需扩展 return s+i ; 即可*/
}