In an alien language, surprisingly, they also use English lowercase letters, but possibly in a different order. The order of the alphabet is some permutation of lowercase letters.
Given a sequence of words written in the alien language, and the order of the alphabets, return true if and only if the given words are sorted lexicographically in this alien language.
Example 1:
Input: words = ["dag","disk","dog"], order = "hlabcdefgijkmnopqrstuvwxyz"
Output: trueExplanation: The first character of the strings are same ('d'). 'a', 'i', 'o' follows the given ordering, which makes the given strings follow the sorted lexicographical order.
Example 2:
Input: words = ["neetcode","neet"], order = "worldabcefghijkmnpqstuvxyz"
Output: falseExplanation: The first 4 characters of both the strings match. But size of "neet" is less than that of "neetcode", so "neet" should come before "neetcode".
Constraints:
1 <= words.length <= 1001 <= words[i].length <= 20order.length == 26words[i] and order are English lowercase letters.Before attempting this problem, you should be comfortable with:
If the words are sorted according to the alien dictionary order, they should remain in the same order after sorting. The key insight is that we can create a mapping from each character to its position in the alien alphabet, then use this mapping to define a custom comparator for sorting.
order string.words array using this custom comparator.true if they are identical.Where is the number of words and is the average length of a word.
For a list to be sorted, each adjacent pair must be in the correct order. Instead of sorting, we can directly verify that each word is lexicographically less than or equal to the next word according to the alien order. This avoids the overhead of sorting.
order string.w1, w2) in the array.w1 is longer than w2 and all compared characters match, return false (prefix violation).w1's character has a smaller index than w2's character in alien order. If not, return false.true.class Solution:
def isAlienSorted(self, words: List[str], order: str) -> bool:
order_index = {c: i for i, c in enumerate(order)}
for i in range(len(words) - 1):
w1, w2 = words[i], words[i + 1]
for j in range(len(w1)):
if j == len(w2):
return False
if w1[j] != w2[j]:
if order_index[w1[j]] > order_index[w2[j]]:
return False
break
return TrueWhere is the number of words and is the average length of a word.
When comparing two words where one is a prefix of the other (e.g., "apple" and "app"), the shorter word must come first. If the longer word appears before its prefix in the list, the order is invalid. Many solutions forget to check this case and only compare differing characters.
When comparing adjacent words character by character, you must break out of the loop as soon as you find the first differing character. Continuing to compare after finding a difference can lead to incorrect conclusions, as only the first difference determines the relative order of two words.