javascript/js 算法题练习 之 实现 strStr()

题目:

实现 strStr() 函数。

给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如果不存在,则返回  -1。

示例 1:

输入: haystack = "hello", needle = "ll"
输出: 2


示例 2:

输入: haystack = "aaaaa", needle = "bba"
输出: -1


说明:

当 needle 是空字符串时,我们应当返回什么值呢?这是一个在面试中很好的问题。

对于本题而言,当 needle 是空字符串时我们应当返回 0 。这与C语言的 strstr() 以及 Java的 indexOf() 定义相符。

 

我的解答:

用slice即可。

循环遍历出在haystack中,所有和needle相同长度的字符串
例如 hello 中有 he el ll lo
再拿它与needle对比就行了

var strStr = function(haystack, needle) {
  var ans = -1
  for(i=0;i<=haystack.length-needle.length;){
    if( needle !== haystack.slice(i,i+(needle.length)) ){
      i++
    }else{
      ans = i
      return ans
    }
  }
  return ans
};

结果:

原文链接:https://leetcode-cn.com/problems/implement-strstr/solution/javascriptjs-yong-sliceji-ke-by-cheng-zi-57/ 

你可能感兴趣的:(前端学习中)