zoukankan      html  css  js  c++  java
  • 求两个字符串的最大公共字串

    //今天面试遇到一个有趣的题目 取两个字符串的最大公共字符串
    //解决方案如下:
    
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    
    //先造一个常用函数
    char* strsub( char const* pStrSrc, int iStart, int iLen )
    {
    	if( !pStrSrc || iStart <  0 )
    		return NULL;
    
    	int iStrLen = strlen( pStrSrc );
    
    	char* pStrRes = NULL;
    	if( iLen >= iStrLen - iStart )
    	{
    		pStrRes = (char*)malloc( iStrLen - iStart + 1 );
    
    		if( !pStrRes )
    			return NULL;
    
    		memset( pStrRes, 0,  iStrLen - iStart + 1 );
    
    		strncpy( pStrRes, pStrSrc + iStart, iStrLen  - iStart );
    
    		return pStrRes;
    	}
    	else
    	{
    		pStrRes = (char*)malloc( iLen + 1 );
    		
    		if( !pStrRes )
    			return NULL;
    
    		memset( pStrRes, 0, iLen + 1 );
    
    		strncpy( pStrRes, pStrSrc + iStart, iLen );
    
    		return pStrRes;
    
    	}
    
    }
    
    char* maxComm( char* pStrLeft, char* pStrRight )
    {
    	if( !pStrLeft || !pStrRight )
    	{
    		return NULL;
    	}
    
    	char* pStrLess = NULL;
    	char* pStrMore = NULL;
    	char* pStrRes= NULL;
    
    	int iLeft = strlen( pStrLeft );
    	int iRight = strlen( pStrRight );
    
    	int iLess = ( iLeft <= iRight ) ? iLeft : iRight;
    
    	int i,j;
    	
    	if( iLeft <= iRight )
    	{
    		pStrLess = pStrLeft;
    		pStrMore = pStrRight;
    	}
    	else
    	{
    		pStrLess = pStrRight;
    		pStrMore = pStrLeft;
    	}
    	char* pSt = NULL;
    
    	for( i = iLess; i > 0; i-- )
    	{
    		for( j = 0; j <= iLess - i; j++ )
    		{
    			pStrRes = strsub( pStrLess, j, i );
    
    			if( strstr( pStrMore, pStrRes ) )
    				return pStrRes;
    
    			free( pStrRes );
    			pStrRes = NULL;
    		}
    	}
    
    	return NULL;
    }
    
    int main( int argc, char** argv )
    {
    	char* pStrLeft = "adasdfabc";
    	char* pStrRight = "asdabcasdf";
    
    	puts( "max comm string between two strings" );
    	char* strMaxComm = maxComm( pStrLeft, pStrRight );
    	printf( strMaxComm );
    	puts( "" );
    
    	free( strMaxComm );
    	strMaxComm = NULL;
    
    	return 0;
    }



  • 相关阅读:
    Socket_leaks open socket #5024 left in connection
    阿里云 如何减少备份使用量? mysql数据库的完整备份、差异备份、增量备份
    一个正则式引发的血案 贪婪、懒惰与独占
    linux下tmp目录里很多php开头的文件
    后端线上服务监控与报警方案
    架构先行
    数据盘缩容
    文件过滤 批量删除
    mock数据(模拟后台数据)
    如何避免升级 Linux 实例内核后无法启动
  • 原文地址:https://www.cnblogs.com/aukle/p/3221692.html
Copyright © 2011-2022 走看看