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

letecode [28] - Implement strStr()

时间:2019-06-03 12:43:42      阅读:98      评论:0      收藏:0      [点我收藏+]

标签:rac   c++   lang   api   int   第一个   函数   class   第一个字符   

Implement strStr().

Return the index of the first occurrence of needle in haystack, or -1 if needle is not part of haystack.

Example 1:

Input: haystack = "hello", needle = "ll"
Output: 2

Example 2:

Input: haystack = "aaaaa", needle = "bba"
Output: -1

Clarification:

What should we return when needle is an empty string? This is a great question to ask during an interview.

For the purpose of this problem, we will return 0 when needle is an empty string. This is consistent to C‘s strstr() and Java‘s indexOf().

题目大意:

  实现函数strStr().

  在字符串haystack中查找needle字符串第一次出现的位置,找到返回第一个字符出现的下标,未找到返回-1.

理  解 :

  遍历字符串haystack,设置指针 i , 与needle字符串的首字符进行比较,若相等则依次比较后面的字符串。

  若 与needle字符串 所有字符均相等,即needle指针j 指向末尾,即返回标记的首字符相等的位置flag。

  若 仅部分字符相等,则从首字符flag后的一个字符开始重新与needle字符串比较。

代 码 C++:

  

class Solution {
public:
    int strStr(string haystack, string needle) {
        if(needle=="") return 0;
        if(haystack=="") return -1;
        int i=0,j,flag;
        while(haystack[i]!=\0){
            j = 0;
            flag = i;
            while(haystack[i]!=\0 && needle[j]!=\0 && haystack[i]==needle[j]){
                ++i;
                ++j;
            }
            if(needle[j]==\0) return flag;
            if(haystack[i]==\0) return -1;
            flag++;
            i = flag;
        }
        return -1;
    }
};

 

运行结果:

  执行用时 : 8 ms  内存消耗 : 8.9 MB

letecode [28] - Implement strStr()

标签:rac   c++   lang   api   int   第一个   函数   class   第一个字符   

原文地址:https://www.cnblogs.com/lpomeloz/p/10966520.html

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