黑马程序员技术交流社区

标题: 找出多个字符串中的最大公共子字符串,如“nbitheimanb [打印本页]

作者: yufanyufan77    时间: 2015-10-11 15:27
标题: 找出多个字符串中的最大公共子字符串,如“nbitheimanb
#include"stdio.h"
#include"string.h"
struct equeString
{
        char equeStr[100];//公共字符串
        int  counts;//公共字符串的长度
};

struct equeString strfg1[100];
struct equeString strfg2[100];
//把一个字符串按照指定长度分割成n个长度相等的字符串如:指定长度是3,
//要被分割的字符是itcast,那么分割的结果是:itc、tca、cas、ast
//len:数组的长度 *p指向要被分割的字符串 lenfg:指定分割的长度

int fenge(int len,char*p,int lenfg)
{
        //分割之后数组的个数
        int strfgCounts;
        //定义一个临时变量
        int temp,temp1;
        strfgCounts = len-lenfg+1;
        for( temp=0 ; temp<strfgCounts ; temp++ )
        {
                for(temp1=0; temp1<lenfg; temp1++)
                {
                   strfg1[temp].equeStr[temp1] = *( p+temp1 + (temp ) );
                }
                strfg1[temp].equeStr[temp1+1] = '\0';
        }
               
        return strfgCounts;
}

//把一个字符串按照指定长度分割成n个长度相等的字符串如:指定长度是3,
//要被分割的字符是itcast,那么分割的结果是:itc、tca、cas、ast
//len:数组的长度 *p指向要被分割的字符串 lenfg:指定分割的长度
int fenge2(int len,char*p,int lenfg)
{
        //分割之后数组的个数
        int strfgCounts;
        //定义一个临时变量
        int temp,temp1;
        strfgCounts = len-lenfg+1;
        for( temp=0 ; temp<strfgCounts ; temp++ )
        {
                for(temp1=0; temp1<lenfg; temp1++)
                {
                   strfg2[temp].equeStr[temp1] = *( p+temp1 + (temp ) );
                }
                strfg2[temp].equeStr[temp1+1] = '\0';
        }
               
        return strfgCounts;
}
//找出多个字符串中的最大公共子字符串,如“nbitheimanb”和“itheia”的最大子串是:”ithei”。
int main(void)
{

        //定义一个变量用来存储
        int maxcounts = 0;
        //定义一个临时变量

        int temp = 0;
        int temp1 = 0;
        int temp2 = 0;
        int temp3 = 0;
        int temp4 = 0;

        //定义两个字符串变量用来存储键盘输入的字符串

        char str1[100] , str2[100];

       
        printf("请输入字符串1\n");
        gets(str1);

        printf("请输入字符串2\n");
        gets(str2);
       
    //寻找最大公共部分

        if(strlen(str1) < strlen(str2))
        {
       
                printf("字符串1的长度是:%d\n字符串2的长度是:%d\n",strlen(str1),strlen(str2));
                 for( temp = strlen(str1); temp > 0; temp-- )
                 {
                        //分割键盘输入的字符串 把分割之后的字符串个数分别存入temp1、特姆坡中
                        temp1 = fenge(strlen(str1),str1,temp);
                        temp2 = fenge2(strlen(str2),str2,temp);
       
                        //通过循环来比较分割之后的字符串是否相等
                        for( temp4 = 0; temp4<temp2; temp4++)
                        {
                                for( temp3 = 0; temp3<temp1 ; temp3++)
                                {
                                        //比较两个字符是否相等
                                        if( strcmp(strfg2[temp4].equeStr , strfg1[temp3].equeStr ) == 0 )
                                        {
                                                maxcounts = 1 ;
                                                printf("最大公共字符串为:");
                                                puts( strfg2[temp4].equeStr );
                                        }                                       
                                }
                        }
                        if( maxcounts == 1 )
                        {
                                return 0;       
                        }
                 }
        }
        else if(strlen(str1) > strlen(str2))
        {
                for( temp = strlen(str1); temp > 0; temp-- )
                 {
                        //分割键盘输入的字符串 把分割之后的字符串个数分别存入temp1、特姆坡中
                        temp1 = fenge(strlen(str1),str1,temp);
                        temp2 = fenge2(strlen(str2),str2,temp);
       
                        //通过循环来比较分割之后的字符串是否相等
                        for( temp4 = 0; temp4<temp1; temp4++)
                        {
                                for( temp3 = 0; temp3<temp2 ; temp3++)
                                {
                                        //比较两个字符是否相等
                                        if( strcmp(strfg2[temp3].equeStr , strfg1[temp4].equeStr ) == 0 )
                                        {
                                                maxcounts = 1 ;
                                                printf("最大公共字符串为:");
                                                puts( strfg2[temp3].equeStr );
                                        }                                       
                                }
                        }
                        if( maxcounts == 1 )
                        {
                                return 0;       
                        }
                 }
                 
        }
         if( strcmp (str1,str2 ) == 0)
        {
               
                {
                        maxcounts = 1 ;
                        printf("最大公共字符串为:");
                        puts(str1);
                }
        }
return 0 ;
}


作者: yufanyufan77    时间: 2015-10-11 17:04
用了最笨的的办法实现的,有很多地方需要优化,如:结构体数组可以定义成二维数组……




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2