本题要求实现一个函数,对给定的一个字符串和两个字符,打印出给定字符串中从与第一个字符匹配的位置开始到与第二个字符匹配的位置之间的所有字符。
函数接口定义:
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 )
//1.打印s中从ch1到ch2之间的所有字符,
//2.返回ch1的地址。
{
int i=0,j,k;
int length;
//把p移动到ch1的位置,p即ch1的地址
while(s[i]!='\0') i++;
length=i;
//遇到个问题,新定义的字符串常量是不能赋值的。
//新的字符串常量只能指向字符串的地址。
for(j=0;j<length;j++)
{
if(s[j]==ch1)
{
for(k=j;k<length;k++)
{
if(s[k]!=ch2)
printf("%c",s[k]);
else
{
printf("%c\n",s[k]);
return s+j; //ch1,ch2都存在
}
}
printf("\n"); //只有ch1,输出到底在换行
return s+j;
}
}
printf("\n"); //ch1不存在的情况下,换行输出
return s+j;
}