<p>You are given a string <code>s</code> and an array of strings <code>words</code> of <strong>the same length</strong>. Return all starting indices of substring(s) in <code>s</code> that is a concatenation of each word in <code>words</code> <strong>exactly once</strong>, <strong>in any order</strong>, and <strong>without any intervening characters</strong>.</p> <p>You can return the answer in <strong>any order</strong>.</p> <p> </p> <p><strong>Example 1:</strong></p> <pre> <strong>Input:</strong> s = "barfoothefoobarman", words = ["foo","bar"] <strong>Output:</strong> [0,9] <strong>Explanation:</strong> Substrings starting at index 0 and 9 are "barfoo" and "foobar" respectively. The output order does not matter, returning [9,0] is fine too. </pre> <p><strong>Example 2:</strong></p> <pre> <strong>Input:</strong> s = "wordgoodgoodgoodbestword", words = ["word","good","best","word"] <strong>Output:</strong> [] </pre> <p><strong>Example 3:</strong></p> <pre> <strong>Input:</strong> s = "barfoofoobarthefoobarman", words = ["bar","foo","the"] <strong>Output:</strong> [6,9,12] </pre> <p> </p> <p><strong>Constraints:</strong></p> <ul> <li><code>1 <= s.length <= 10<sup>4</sup></code></li> <li><code>s</code> consists of lower-case English letters.</li> <li><code>1 <= words.length <= 5000</code></li> <li><code>1 <= words[i].length <= 30</code></li> <li><code>words[i]</code> consists of lower-case English letters.</li> </ul>