zoukankan      html  css  js  c++  java
  • LintCode 13. Implement strStr() 字符串匹配KMP问题,抄的答案不会写Next函数

    public class StrStr {
        /**
         * @param source: source string to be scanned.
         * @param target: target string containing the sequence of characters to match
         * @return: a index to the first occurrence of target in source, or -1  if target is not part of source.
         * 13. Implement strStr()
         */
        public int strStr(String source, String target) {
            if (source == null || target == null) {
                return -1;
            }
            if (source.equals(target)) {
                return 1;
            } else if (target.length()==0) {
                return -1;
            }
            char[] t = source.toCharArray();
            char[] p = target.toCharArray();
            int i = 0; // 主串的位置
            int j = 0; // 模式串的位置
            int[] next = getNext(target);
            while (i < t.length && j < p.length) {
                if (j == -1 || t[i] == p[j]) { // 当j为-1时,要移动的是i,当然j也要归0
                    i++;
                    j++;
                } else {
                    // i不需要回溯了
                    // i = i - j + 1;
                    j = next[j]; // j回到指定位置
                }
            }
            if (j == p.length) {
                return i - j;
            } else {
                return -1;
            }
        }
    
        public static int[] getNext(String ps) {
            char[] p = ps.toCharArray();
            int[] next = new int[p.length];
            next[0] = -1;
            int j = 0;
            int k = -1;
            while (j < p.length - 1) {
                if (k == -1 || p[j] == p[k]) {
                    if (p[++j] == p[++k]) { // 当两个字符相等时要跳过
                        next[j] = next[k];
                    } else {
                    }
                } else {
                    k = next[k];
                }
            }
            return next;
        }
    }
    
  • 相关阅读:
    抓不住重点
    打瞌睡的一周
    培养专门领域技能的同时不要忘记通用性和可迁移性技能
    H.265 Video Encoder IP Core
    人最重要的能力---转载
    写写视频多媒体的内容
    关于做开发的一点感想
    android安全技术技能清单
    Callable,Future,FutureTask
    软件工程作业汇总(网络14、15、16)
  • 原文地址:https://www.cnblogs.com/wei1/p/9582059.html
Copyright © 2011-2022 走看看