码迷,mamicode.com
首页 > 其他好文 > 详细

lintcode-easy-strStr

时间:2016-03-11 08:52:50      阅读:181      评论:0      收藏:0      [点我收藏+]

标签:

For a given source string and a target string, you should output the first index(from 0) of target string in source string.

If target does not exist in source, just return -1.

If source = "source" and target = "target", return -1.

If source = "abcdabcdefg" and target = "bcd", return 1.

 

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;
        
        if(source.length() == 0 && target.length() == 0)
            return 0;
        if(target.length() == 0)
            return 0;
        
        int size1 = source.length();
        int size2 = target.length();
        
        if(size1 < size2)
            return -1;
        
        for(int i = 0; i <= size1 - size2; i++){
            if(source.charAt(i) == target.charAt(0)){
                int j = 0;
                for(; j < size2; j++){
                    if(source.charAt(i + j) != target.charAt(j))
                        break;
                }
                if(j == size2)
                    return i;
            }
        }
        
        return -1;
    }
}

 

lintcode-easy-strStr

标签:

原文地址:http://www.cnblogs.com/goblinengineer/p/5264191.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!