Skip to content

Latest commit

 

History

History
104 lines (69 loc) · 2.68 KB

2746-decremental-string-concatenation.adoc

File metadata and controls

104 lines (69 loc) · 2.68 KB

2746. Decremental String Concatenation

{leetcode}/problems/decremental-string-concatenation/[LeetCode - 2746. Decremental String Concatenation ^]

You are given a 0-indexed array words containing n strings.

Let’s define a join operation join(x, y) between two strings x and y as concatenating them into xy. However, if the last character of x is equal to the first character of y, one of them is deleted.

For example join("ab", "ba") = "aba" and join("ab", "cde") = "abcde".

You are to perform n - 1 join operations. Let str<sub>0</sub> = words[0]. Starting from i = 1 up to i = n - 1, for the ith operation, you can do one of the following:

  • Make str<sub>i</sub> = join(str<sub>i - 1</sub>, words[i])

  • Make str<sub>i</sub> = join(words[i], str<sub>i - 1</sub>)

Your task is to minimize the length of str<sub>n - 1</sub>.

Return an integer denoting the minimum possible length of str<sub>n - 1</sub>.

Example 1:

Input: words = ["aa","ab","bc"]
Output: 4
*Explanation: *In this example, we can perform join operations in the following order to minimize the length of str<sub>2</sub>:
str<sub>0</sub> = "aa"
str<sub>1</sub> = join(str<sub>0</sub>, "ab") = "aab"
str<sub>2</sub> = join(str<sub>1</sub>, "bc") = "aabc"
It can be shown that the minimum possible length of str<sub>2</sub> is 4.

Example 2:

Input: words = ["ab","b"]
Output: 2
Explanation: In this example, str<sub>0</sub> = "ab", there are two ways to get str<sub>1</sub>:
join(str<sub>0</sub>, "b") = "ab" or join("b", str<sub>0</sub>) = "bab".
The first string, "ab", has the minimum length. Hence, the answer is 2.

Example 3:

Input: words = ["aaa","c","aba"]
Output: 6
Explanation: In this example, we can perform join operations in the following order to minimize the length of str<sub>2</sub>:
str<sub>0</sub> = "aaa"
str<sub>1</sub> = join(str<sub>0</sub>, "c") = "aaac"
str<sub>2</sub> = join("aba", str<sub>1</sub>) = "abaaac"
It can be shown that the minimum possible length of str<sub>2</sub> is 6.

<div class="notranslate" style="all: initial;">

Constraints:

  • 1 ⇐ words.length ⇐ 1000

  • 1 ⇐ words[i].length ⇐ 50

  • Each character in words[i] is an English lowercase letter

思路分析

一刷
link:{sourcedir}/_2746_DecrementalStringConcatenation.java[role=include]

参考资料