
Problem
Solution
Submissions
Edit Distance
Certification: Advanced Level
Accuracy: 0%
Submissions: 0
Points: 15
Write a C# program to implement the EditDistance(string word1, string word2) function, which calculates the minimum number of operations required to convert word1 to word2. The allowed operations are:
- Insert a character
- Delete a character
- Replace a character
Example 1
- Input: word1 = "horse", word2 = "ros"
- Output: 3
- Explanation:
- horse → rorse (replace 'h' with 'r')
- rorse → rose (remove 'r')
- rose → ros (remove 'e')
Example 2
- Input: word1 = "intention", word2 = "execution"
- Output: 5
- Explanation:
- intention → inention (remove 't')
- inention → enention (replace 'i' with 'e')
- enention → exention (replace 'n' with 'x')
- exention → exection (replace 'n' with 'c')
- exection → execution (insert 'u')
Constraints
- 0 <= word1.length, word2.length <= 500
- word1 and word2 consist of lowercase English letters
- Time Complexity: O(m * n) where m and n are lengths of the two strings
- Space Complexity: O(m * n)
Editorial
My Submissions
All Solutions
Lang | Status | Date | Code |
---|---|---|---|
You do not have any submissions for this problem. |
User | Lang | Status | Date | Code |
---|---|---|---|---|
No submissions found. |
Solution Hints
- Use dynamic programming to solve this problem efficiently
- Create a 2D array to store intermediate results
- Consider all three operations at each step and choose the minimum
- The value at dp[i][j] represents the minimum edit distance between word1[0...i-1] and word2[0...j-1]
- Base cases: converting an empty string to a non-empty string requires insertions equal to the length