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 == 26
keyboard
contains each English lowercase letter exactly once in some order.1 <= word.length <= 10^4
word[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.