本题要求实现一个函数,对给定的一个字符串和两个字符,打印出给定字符串中从与第一个字符匹配的位置开始到与第二个字符匹配的位置之间的所有字符。
函数接口定义:
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
来源:
来源:PTA | 程序设计类实验辅助教学平台
链接:https://pintia.cn/problem-sets/13/exam/problems/592
提交:
题解:
#include <string.h>
/*
* 打印 s 中从 ch1 到 ch2 之间的所有字符,并且返回 ch1 的地址
*/
char *match(char *s, char ch1, char ch2) {
// index 记录 ch1 在 s 中的下标值
int index = -1;
for (int i = 0; s[i] != '\0'; i++) {
if (s[i] == ch1) {
index = i;
break;
}
}
// s 中存在 ch1
if (index > -1) {
// 输出 s 中 ch1 到 ch2 间的所有字符
for (int j = index; s[j] != '\0'; j++) {
printf("%c", s[j]);
if (s[j] == ch2) {
break;
}
}
}
// 按题目格式要求打印换行符
printf("\n");
// 若 s 中存在 ch1 则返回 ch1 的地址,否则返回 s 的字符串结束标记符 '\0' 的地址
return index > -1 ? s + index : s + strlen(s);
}