1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-25 17:50:26 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode-cn/problem (Chinese)/字符串连接删减字母 [decremental-string-concatenation].html
2023-07-03 20:48:37 +08:00

62 lines
2.9 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<p>给你一个下标从 <strong>0</strong>&nbsp;开始的数组&nbsp;<code>words</code>&nbsp;,它包含 <code>n</code>&nbsp;个字符串。</p>
<p>定义 <strong>连接</strong>&nbsp;操作&nbsp;<code>join(x, y)</code>&nbsp;表示将字符串&nbsp;<code>x</code>&nbsp;<code>y</code>&nbsp;连在一起,得到&nbsp;<code>xy</code>&nbsp;。如果&nbsp;<code>x</code>&nbsp;的最后一个字符与&nbsp;<code>y</code>&nbsp;的第一个字符相等,连接后两个字符中的一个会被&nbsp;<strong>删除</strong>&nbsp;</p>
<p>比方说&nbsp;<code>join("ab", "ba") = "aba"</code>&nbsp;&nbsp;<code>join("ab", "cde") = "abcde"</code>&nbsp;</p>
<p>你需要执行&nbsp;<code>n - 1</code>&nbsp;&nbsp;<strong>连接</strong>&nbsp;操作。令&nbsp;<code>str<sub>0</sub> = words[0]</code>&nbsp;,从&nbsp;<code>i = 1</code> 直到&nbsp;<code>i = n - 1</code>&nbsp;,对于第&nbsp;<code>i</code>&nbsp;个操作,你可以执行以下操作之一:</p>
<ul>
<li>&nbsp;<code>str<sub>i</sub> = join(str<sub>i - 1</sub>, words[i])</code></li>
<li>&nbsp;<code>str<sub>i</sub> = join(words[i], str<sub>i - 1</sub>)</code></li>
</ul>
<p>你的任务是使&nbsp;<code>str<sub>n - 1</sub></code>&nbsp;的长度<strong>&nbsp;最小&nbsp;</strong></p>
<p>请你返回一个整数,表示&nbsp;<code>str<sub>n - 1</sub></code>&nbsp;的最小长度。</p>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<pre>
<b>输入:</b>words = ["aa","ab","bc"]
<b>输出:</b>4
<strong>解释:</strong>这个例子中,我们按以下顺序执行连接操作,得到 <code>str<sub>2</sub></code> 的最小长度:
<code>str<sub>0</sub> = "aa"</code>
<code>str<sub>1</sub> = join(str<sub>0</sub>, "ab") = "aab"
</code><code>str<sub>2</sub> = join(str<sub>1</sub>, "bc") = "aabc"</code>
<code>str<sub>2</sub></code> 的最小长度为 4 。</pre>
<p><strong>示例 2</strong></p>
<pre>
<b>输入:</b>words = ["ab","b"]
<b>输出:</b>2
<b>解释:</b>这个例子中str<sub>0</sub> = "ab",可以得到两个不同的 str<sub>1</sub>
join(str<sub>0</sub>, "b") = "ab" 或者 join("b", str<sub>0</sub>) = "bab" 。
第一个字符串 "ab" 的长度最短,所以答案为 2 。
</pre>
<p><strong>示例 3</strong></p>
<pre>
<b>输入:</b>words = ["aaa","c","aba"]
<b>输出:</b>6
<b>解释:</b>这个例子中,我们按以下顺序执行连接操作,得到 <code>str<sub>2</sub>&nbsp;的最小长度:</code>
<code>str<sub>0</sub> = "</code>aaa"
<code>str<sub>1</sub> = join(str<sub>0</sub>, "c") = "aaac"</code>
<code>str<sub>2</sub> = join("aba", str<sub>1</sub>) = "abaaac"</code>
<code>str<sub>2</sub></code> 的最小长度为 6 。
</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>1 &lt;= words.length &lt;= 1000</code></li>
<li><code>1 &lt;= words[i].length &lt;= 50</code></li>
<li><code>words[i]</code>&nbsp;中只包含小写英文字母。</li>
</ul>