zoukankan      html  css  js  c++  java
  • lintcode:strStr 字符串查找

    题目:

    字符串查找(又称查找子字符串),是字符串操作中一个很有用的函数。你的任务是实现这个函数。

    对于一个给定的 source 字符串和一个 target 字符串,你应该在 source 字符串中找出 target 字符串出现的第一个位置(从0开始)。

    如果不存在,则返回 -1

    样例

    如果 source = "source" 和 target = "target",返回 -1

    如果 source = "abcdabcdefg" 和 target = "bcd",返回 1

    挑战

    O(n2)的算法是可以接受的。如果你能用O(n)的算法做出来那更加好。(提示:KMP)

    说明

    在面试中我是否需要实现KMP算法?

    • 不需要,当这种问题出现在面试中时,面试官很可能只是想要测试一下你的基础应用能力。当然你需要先跟面试官确认清楚要怎么实现这个题。

    解题:

    暴力破解,时间复杂度O(mn)

    Java程序:

    class Solution {
        /**
         * Returns a index to the first occurrence of target in source,
         * or -1  if target is not part of source.
         * @param source string to be scanned.
         * @param target string containing the sequence of characters to match.
         */
        public int strStr(String source, String target) {
            //write your code here
            
            if(source==null || target==null)
                return -1;
            int sourceLen = source.length();
            int targetLen = target.length();
            if(targetLen==0)
                return 0;
            if(targetLen>sourceLen)
                return -1;
            
            for(int i=0;i<sourceLen;i++){
                if(sourceLen -i <targetLen)
                    return -1;
                int k = i;
                for(int j = 0;j<targetLen;j++){
                    if(source.charAt(k) == target.charAt(j)){
                        if(j==targetLen-1)
                            return i;
                        k++;
                    }else
                        break;
                }
            }
            return -1;
        }
    }
    View Code

    总耗时: 1332 ms

    Python程序:

    class Solution:
        def strStr(self, source, target):
            # write your code here
            if source==None or target ==None:
                return -1
            if len(target)==0:
                return 0 
            sourcelen = len(source)
            targetlen = len(target)
            for i in range(sourcelen):
                k = i
                for j in range(targetlen):
                    if source[k]==target[j]:
                        if j==targetlen-1:
                            return i
                        k+=1
                    else:
                        break
                    
            return -1
    View Code

    总耗时: 299 ms

    对于应用KMP算法的,待更新

  • 相关阅读:
    Amphiphilic Carbon Molecules [UVA
    2018宁夏邀请赛I题 bubble sort(思维题
    CF1198E Rectangle Painting 2(最小割 思维
    Problem : 这个题如果不是签到题 Asm.Def就女装(积性函数dp
    cogs2223. [SDOI2016 Round1] 生成魔咒(后缀数组 hash 二分 set
    cogs1709. [SPOJ 705] 不同的子串(后缀数组
    cogs249 最长公共子串(后缀数组 二分答案
    hdu2222 Keywords Search (AC自动机板子
    ccpc网赛 hdu6703 array(权值线段树
    ccpc网赛 hdu6705 path(队列模拟 贪心
  • 原文地址:https://www.cnblogs.com/bbbblog/p/4873113.html
Copyright © 2011-2022 走看看