习题11-5 指定位置输出字符串 (20point(s)).c

本题要求实现一个函数,对给定的一个字符串和两个字符,打印出给定字符串中从与第一个字符匹配的位置开始到与第二个字符匹配的位置之间的所有字符。

函数接口定义:

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
//   Date:2020/4/8
//   Author:xiezhg5
#include <stdio.h>
#include <string.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;
}

/* 你的代码将被嵌在这里 */
char *match( char *s, char ch1, char ch2 ){
    int i,flag=0,d=-1,count=0; //count 用来标志第一次找到ch1,和第一次找到ch2 避免有重复的
    for(i=0;i<strlen(s);i++){
        if(s[i]==ch1&&count==0){
            flag = 1;
            d = i;
            count++;
        }
        if(flag==1){
            printf("%c",s[i]);
        }
        if(s[i]==ch2&&count==1){
            flag = 0;
            count++;
        }
    }
    printf("\n");
    if(d!=-1){
    return &s[d];
    }else{
        return s+strlen(s); //输出空行,就输出s的最后一个地址的后一位即可,返回NULL这里通不过
    }
}

发布了208 篇原创文章 · 获赞 182 · 访问量 8640

猜你喜欢

转载自blog.csdn.net/qq_45645641/article/details/105393537