zoukankan      html  css  js  c++  java
  • 编程之美3.1 字符串移位包括问题

          这道题目的意思是给定一个字符串,作为源字符串。之后给出其它的字符串,确定源字符串能否够经过旋转而得到给定的字符串,即移位包括问题。

          假如,给定一个字符串 abcdefg,接着给定字符串 cdefgab,非常显然,给定的字符串是能够经过源字符串旋转而得到的,可是,给定字符串 cdegfab 就不能由源字符串经过旋转而得到。

          当然,这道题有非常多解法,我们能够经过推断字符串中字符的位置而得到答案,可是。那样做确实是太麻烦了。有更好的解法吗?当然。我们看下两个字符串的规律,当把源字符串 * 2 时。即拼接在一块,仅仅要是给定字符串能经过源字符串旋转而得到,那么,给定的字符串一定在源字符串 * 2中。比如。前面的样例。把源字符串 * 2 ,能够得到的字符串是 abcdefgabcdefg。我们能够看到,给定的字符串确实是出如今当中的。

          好了,有了上述思想,我们能够利用 strstr 函数求解这个问题了,strstr 函数是返回目的字符串出如今源字符串的位置,假设返回 NULL,那么就不存在。即不能经过源字符串旋转而得到。

          函数声明:

    bool DutShiftContains_1(char*, char*);

          源码:

    bool DutShiftContains_1(char* str1, char* str2)
    {
    	if (!str1 || !str2)
    		return false;
    
    	size_t len = strlen(str1);
    
    	/*对原字符串进行拼接*/
    	char* _str1 = new char[2 * len + 1];
    	strcpy_s(_str1, 2 * len + 1, str1);
    	strcat_s(_str1, 2 * len + 1, str1);
    
    	bool result = strstr(_str1, str2) == NULL ?

    false : true; delete[] _str1; return result; }

          如今。我们来思考书后的扩展。即不申请别的空间,能求解这个问题吗?由于。须要拼接字符串自然须要申请很多其它的空间。

          答案是:能够。我们虚拟的来做。即当达到源字符串的末尾时,从源字符串的开头处比对不即可了吗。

    当然。这就是取余的方法了。

          函数声明:

    bool DutShiftContains_2(char*, char*);

          源码:

    bool DutShiftContains_2(char* str1, char* str2)
    {
    	if (!str1 || !str2)
    		return false;
    
        size_t len1 = strlen(str1);
        size_t len2 = strlen(str2);
    
        if (len1 != len2)
        {
            return false;
        }
    
    	/*模拟拼接处理*/
    	for (int i = 0; i != len1; ++i)
        {
            if (str1[i] == str2[0])
            {
                int j = 1;
                while (str1[(i + j) % len1] == str2[j++])
                {
                    if (str2[j] == '')
                        return true;
                }
            }
        }
    
        return false;
    }



  • 相关阅读:
    8.移动和重命名文件
    7.复制文件和目录
    22.变基
    21.拉取&删除远程分支
    程序员必备课程——网络编程入门
    正则表达式——Java程序员懂你
    编程语言的基础——搞定JavaIO
    需加装饰——装饰模式
    结合提供者模式解析Jenkins源码国际化的实现
    算法族的集中管理——策略模式
  • 原文地址:https://www.cnblogs.com/wgwyanfs/p/7169293.html
Copyright © 2011-2022 走看看