本题要求实现一个函数,对给定的一个字符串和两个字符,打印出给定字符串中从与第一个字符匹配的位置开始到与第二个字符匹配的位置之间的所有字符。
函数接口定义:
char *match( char *s, char ch1, char ch2 );
函数match
应打印s
中从ch1
到ch2
之间的所有字符,并且返回ch1
的地址。
裁判测试程序样例:
#include #define MAXS 10char *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:
programr g
输出样例1:
rogrogram
输入样例2:
programz o
输出样例2:
(空行)(空行)
输入样例3:
programg z
输出样例3:
gramgram
//指定位置输出字符串#define MAXS 10char* match(char* s, char ch1, char ch2){int i = 0;while (*s != '\0' && *s != ch1){s++;}char* index = s;//标记起始坐标if (*s != '\0')//如果这不是终点就继续找终点{//从起点找到结束for (*(++s); *s != '\0'; ++s){if (*s == ch2){*(++s) = '\0';//找到重点就直接给后一位赋值结束break;//节省时间,提高效率}}}return index;//把起始坐标传送回去}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;}