编程练习,寻找字符串中的子串

#include <stdio.h>
#include <string.h>

#define MAX_SIZE 1024

int my_strncmp(char *src, char *head, int len)
{
    int i;
    
    for(i = 0; i < len; i++)
    {
        if(*(src + i) != *(head + i))
	{
	    return -1;
	}
    }

    return 0;

}

char * find_string(char *head, char *tail, char *src)
{
    int h_len = strlen(head);
    int t_len = strlen(tail);

    char *temp;
    
    while(*src != '\0')
    {
        if(my_strncmp(src,head,h_len) == 0)
	{
            temp = src;
	    src = src + h_len;

	    while(*src != '\0')
	    {
	        if(my_strncmp(src,tail,t_len) == 0)
		{
                    *(src + t_len) = '\0';
		    return temp;
		}

		src++;
	    }

	    return NULL;
	}
	
	src++;
    }

    return NULL;
}

int main()
{
    char src[MAX_SIZE];

    char head[MAX_SIZE];
    char tail[MAX_SIZE];

    printf("Please input source string:\n");
    scanf("%s",src);

    printf("Please input head string:\n");
    scanf("%s",head);

    printf("Please input tail string:\n");
    scanf("%s",tail);

    char *result = find_string(head,tail,src);

    printf("result = %s\n",result);

    
    return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值