Problem
There is a special keyboard with all keys in a single row.
Given a string keyboard of length 26 indicating the layout of the keyboard (indexed from 0 to 25). Initially, your finger is at index 0. To type a character, you have to move your finger to the index of the desired character.
The time taken to move your finger from index i to index j is |i - j|.
You want to type a string word. Write a function to calculate how much time it takes to type it with one finger.
Examples
Example 1:
| |
Example 2:
| |
Constraints:
keyboard.length == 26keyboardcontains each English lowercase letter exactly once in some order.1 <= word.length <= 10^4word[i]is an English lowercase letter.
Solution
Method 1 – Index Mapping and Linear Scan
Intuition
Map each character to its index in the keyboard. For each character in word, compute the distance from the previous character’s index.
Approach
- Build a map from character to index for the keyboard.
- Start at index 0. For each character in word, add the distance from the previous index to the answer.
Code
| |
| |
| |
Complexity
- ⏰ Time complexity:
O(n)— n = len(word), plus O(1) for keyboard mapping. - 🧺 Space complexity:
O(1)— Only a fixed-size map/array is used.