c语言实现传入两个字符串,得出相同最多的子字符串

思路:

1输入两个字符串

2比较谁长

3编写函数

:1找到最长的字符串---遍历时以最长的为基准
:2两个for循环遍历,判断短的字符串的一个字符是否==长的字符串的字符

:3相等后接着往后判断,让数组的下表++;将得到的字符串存入charb【100】中,再接着遍历

再比较哪个最长最终存入b中

代码

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

void substr(char *s1, char *s2, int len)
{
    int i, j, m = 0;
    int p, q;
    int length = strlen(s2);
    char a[100] = {0};
    char b[100] = {0};
    for(i = 0; i < len; i++)
    {
        for(j = 0; j < length; j++)
        {
            strcpy(a, "0");
            p = i;
            q = j;

            while(s1[p] == s2[q] && s1[p] != 0)
            {
                a[m] = s2[q];
                p++;
                q++;
                m++;
            }

            if(strlen(a) > strlen(b))
            {
                strcpy(b, a);
            }
            m = 0;
        }
    }
    printf("最大公子串:%s\n", b);
}

int main()
{
    char str1[100] = {0};
    char str2[100] = {0};
    int len;

    printf("请输入字符串1:");
    scanf("%s", str1);
    printf("请输入字符串2:");
    scanf("%s", str2);

    len = strlen(str1) <= strlen(str2) ? strlen(str1) : strlen(str2);
    if(len == strlen(str1))
    {
        substr(str1, str2, len);    
    }
    else if(len == strlen(str2))
    {
        substr(str2, str1, len);
    }

    return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值