本题要求实现一个函数,对给定的一个字符串和两个字符,打印出给定字符串中从与第一个字符匹配的位置开始到与第二个字符匹配的位置之间的所有字符。
函数接口定义:
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;
char *p;
for(;(i<strlen(s))&&(s[i]!=ch1);i++);
p=&s[i]; //保存起始位置的首地址
for(;i<strlen(s);i++)
{
printf("%c",s[i]);//从起始位置开始输出知道结尾
if(s[i]==ch2)
break;
}
printf("\n");
return p;
}
*/
///////////////////////////////////////////////////
/*法二:
char *match( char *s, char ch1, char ch2 )
{
int index=-1; //-1表示没找到,不是-1表示找到了ch1
for(int i=0;i<strlen(s);i++)
{ //找到ch1以后开始输出字符,找到第一个ch2以后结束输出
if(index==-1&&s[i]==ch1)
index=i;
if(index!=-1)printf("%c",s[i]);
if(index!=-1&&s[i]==ch2)break;
}
printf("\n");
if(index==-1)return s+strlen(s); //如果没找到输出空行,要表示空行,则用字符串最后一位,即s[len]
return s+index;
}
*/
/*
/////////////////////////////////////////////////////////////
法三:
char *match( char *s, char ch1, char ch2 )
{
char *p=s;//先指向s
while(*p!='\0'&&*p!=ch1)
{
p++;
}//查找ch1
char *q=p;
if(*p==ch1&&*q==ch2)
{
printf("%c\n",ch1);
return p;
}//如果ch1与ch2指向同一个字符直接输出
while(*q!='\0'&&*q!=ch2)
{
printf("%c",*q++);
if(*q==ch2)
{
printf("%c",ch2);
}//这是找的到ch1的情况
//先输出再自增移动到下一个位置
}
printf("\n");
//注意格式,在例子中可以发现有输出空行
return p;
}
*/
//////////////////////////////////////////////////////////
法四:
char *match( char *s, char ch1, char ch2 )
{
char *p;
int i,j;
for(i=0;i<strlen(s);i++)
if(s[i]==ch1)break;
p=&s[i];
for(j=i;j<strlen(s);j++)
{
printf("%c",s[j]);
if(s[j]==ch2)break;
}
printf("\n");
return p;
}