Frank's Book
  • Introduction
  • Privacy Policy
  • Git
    • [Git]Fully delete a git repository created with init
  • iOS
    • iOS Book
      • [iOS] Swift Coding Style
      • [iOS] UnitTest With XCode
      • [iOS] Build a Universal Framework for iOS using Swift
      • [iOS] Memory Management
      • [iOS] GCD And Operation Queue
      • [iOS] MVVM
      • [iOS] CoreData
      • [iOS] KVO & KVC
      • [iOS] Asynchronous Operation
      • [iOS] URLSession
      • [iOS] NSTimer & CADisplayLink
      • [iOS] UITextField & UITestView
      • [iOS] UITableView & UICollectionView
      • [iOS] Codable
      • [iOS] Array的sort, filter, map, reduce 函式
      • [iOS] Class vs Struct
      • [iOS] Reference Type vs Value Type
      • [iOS] Object
      • [iOS] IBDesignable & IBInspectable
  • Jenkins
    • Jenkins & Docker
      • [Docker] Docker Commands
      • [Docker] 1. Setup Jenkins with Docker on Mac
      • [Docker] 2. Jenkins建立Mac子節點
      • [Docker] 3. Mac節點build Xcode project設定
      • [Jenkins] 1. Install Jenkins
      • [Jenkins] 2. Change Default User Of Jenkins
      • [Jenkins] 3. Integration with Git
      • [Jenkins] 4. Integration with XCode
      • [Jenkins] 5. Integration with Unit Test
      • [Jenkins] 6. Uninstall Jenkins
      • [Jenkins] 7. Jenkins Commands
      • [Jenkins] 8. Jenkins Plugins
      • [Jenkins] 9. Problem Solving
  • Flutter
    • Flutter Book
      • [Flutter] Update your Flutter path (Mac OS)
      • [Flutter] Release Command
      • [Flutter] Life Cycles
      • [Flutter] AppLifecycleState
      • [Flutter] Navigator Pop時回傳資料
      • [Flutter] Install appium-flutter-driver
  • Leet Code
    • LeetCode Solutions
      • [LeetCode] 1. Two Sum [Easy]
      • [LeetCode] 2. Add Two Numbers [Medium]
      • [LeetCode] 3. Longest Substring Without Repeating Characters [Medium]
      • [LeetCode] 5. Longest Palindromic Substring [Medium]
      • [LeetCode] 7. Reverse Integer [Easy] [LeetCode]
      • [LeetCode] 8. String to Integer (atoi)
      • [LeetCode] 11. Container With Most Water
      • [LeetCode] 13. Roman to Integer
      • [LeetCode]14. Longest Common Prefix
      • [LeetCode] 15. 3Sum
      • [LeetCode] 17. Letter Combinations of a Phone Number
      • [LeetCode] 19. Remove Nth Node From End of List
      • [LeetCode] 20. Valid Parentheses
      • [LeetCode] 21. Merge Two Sorted Lists
      • [LeetCode] 22. Generate Parentheses
      • [LeetCode] 26. Remove Duplicates from Sorted Array
      • [LeetCode] 28. Implement strStr()
      • [LeetCode] 33. Search in Rotated Sorted Array
      • [LeetCode] 34. Find First and Last Position of Element in Sorted Array
      • [LeetCode]36. Valid Sudoku
      • [LeetCode] 38. Count and Say
      • [LeetCode] 46. Permutations
      • [LeetCode] 48. Rotate Image
      • [LeetCode] 49. Group Anagrams
  • Git
    • Git Commands
      • [LeetCode] 50. Pow(x, n)
  • About Author
    • Frank Chen
Powered by GitBook
On this page
  1. Leet Code
  2. LeetCode Solutions

[LeetCode] 28. Implement strStr()

Previous[LeetCode] 26. Remove Duplicates from Sorted ArrayNext[LeetCode] 33. Search in Rotated Sorted Array

Last updated 6 years ago

Implement .

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 and Java's .

Analyse:

​

Solution:

class Solution {
    
    func strStr(_ haystack: String, _ needle: String) -> Int {       
        if(needle.count == 0 ) {
            return 0;
        }
        
        if(haystack.count == 0) {
             return -1;
        }
        
        if(needle.count > haystack.count) {
            return -1;
        }
        
        let chars = Array(haystack);
        let needleChars = Array(needle);
        
        for i in 0..<chars.count - needleChars.count + 1 {
            let char = chars[i];
            
            var iNeedle = false;
            
            if(char == needleChars[0]) {
                iNeedle = true;
                
                for j in 1..<needleChars.count {
                    if(chars[j + i] != needleChars[j]) {
                         iNeedle = false;
                    }
                }
            }
            
            if(iNeedle == true) {
            
                return i;
            }
        }
        
        return -1;
    } 
}

Solution 2:

class Solution {
    func strStr(_ haystack: String, _ needle: String) -> Int {
        var output = -1
        var chars = Array(haystack)
        var needleChars = Array(needle)
        
        if(chars.count == 0) {
            if(needleChars.count != 0) {
                return -1
            } else {
                return 0
            }
            
        } else if(chars.count == 0 || needleChars.count == 0) {
            return 0
        } else if(needleChars.count > chars.count)  {
            return -1
        }

        for i in 0..<chars.count {
             
            let char = chars[i]
            
            if(char == needleChars[0]) {
                var isMatch = true
                var j = 1
                
                while (j < needleChars.count) {
                    
                    if(i + j >= chars.count) {
                        return -1
                    }
                    
                    let charA = chars[i + j]
                    let charB = needleChars[j]
                    
                    if(charA != charB) {
                        isMatch = false
                        break
                    }
                    
                    j += 1
                }
            
                if(isMatch == true) {
                    return i
                }
             
            }
            
        }
        
        return -1
        
    }
}
strStr()
strstr()
indexOf()