Given two strings needle and haystack, return the index of the first occurrence of needle in haystack, or -1 if needle is not part of haystack.
![[Solved] Find the Index of the First Occurrence in a String-28 C++,Java, Python-Microsoft, Google ,Amazon, Media.net  String](https://realcoder.techss24.com/wp-content/uploads/2024/03/4bcff455-4b94-4c5a-908e-9c84e6f60dbf-edited.jpg)
Example 1:
Input: haystack = “sadbutsad”, needle = “sad”
Output: 0
Explanation: “sad” occurs at index 0 and 6. The first occurrence is at index 0, so we return 0.
Example 2:
Input: haystack = “leetcode”, needle = “leeto”
Output: -1
Explanation: “leeto” did not occur in “leetcode”, so we return -1.
Constraints:
- 1 <= haystack.length, needle.length <= 104
- haystackand- needleconsist of only lowercase English characters.
Solution
Intuition
The function is trying to find the index of the first occurrence of the needle string within the haystack string. If the needle is not found in the haystack, it returns -1.
Approach
- Use a loop to iterate through the haystackstring. The loop starts at indexi = 0and goes up toi = haystack.length() - needle.length(). This is done to ensure that there are enough characters left in thehaystackfor the needle to fit.
- Within the loop, check substrings of length equal to the length of the needlestarting from the current indexiup toi + needle.length(). If any of these substrings matches theneedle, return the current indexi.
- If the loop completes without finding a match, return -1.
Complexity
- Time complexity: O(n * m)
- Space complexity: O(1)
class Solution {
public:
    int strStr(std::string haystack, std::string needle) {
        for (int i = 0; i <= haystack.length() - needle.length(); ++i) {
            if (haystack.substr(i, needle.length()) == needle) {
                return i;
            }
        }
        return -1;
    }
};class Solution {
    public int strStr(String haystack, String needle) {
        for(int i = 0, j = needle.length(); j<=haystack.length(); i++,j++){
            if(haystack.substring(i,j).equals(needle)){
                return i;
            }
        }
        return -1;
    }
}class Solution:
    def strStr(self, haystack, needle):
        for i in range(len(haystack) - len(needle) + 1):
            if haystack[i:i+len(needle)] == needle:
                return i
        return -1Happy Learning – If you require any further information, feel free to contact me.
![[Solved] Task Scheduler II LeetCode Contest](https://realcoder.techss24.com/wp-content/uploads/2022/08/Solved-Task-Scheduler-II-LeetCode-Contest-300x200.png)

