mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-26 07:18:56 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			58 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>Two strings are considered <strong>close</strong> if you can attain one from the other using the following operations:</p>
 | |
| 
 | |
| <ul>
 | |
| 	<li>Operation 1: Swap any two <strong>existing</strong> characters.
 | |
| 
 | |
| 	<ul>
 | |
| 		<li>For example, <code>a<u>b</u>cd<u>e</u> -> a<u>e</u>cd<u>b</u></code></li>
 | |
| 	</ul>
 | |
| 	</li>
 | |
| 	<li>Operation 2: Transform <strong>every</strong> occurrence of one <strong>existing</strong> character into another <strong>existing</strong> character, and do the same with the other character.
 | |
| 	<ul>
 | |
| 		<li>For example, <code><u>aa</u>c<u>abb</u> -> <u>bb</u>c<u>baa</u></code> (all <code>a</code>'s turn into <code>b</code>'s, and all <code>b</code>'s turn into <code>a</code>'s)</li>
 | |
| 	</ul>
 | |
| 	</li>
 | |
| </ul>
 | |
| 
 | |
| <p>You can use the operations on either string as many times as necessary.</p>
 | |
| 
 | |
| <p>Given two strings, <code>word1</code> and <code>word2</code>, return <code>true</code><em> if </em><code>word1</code><em> and </em><code>word2</code><em> are <strong>close</strong>, and </em><code>false</code><em> otherwise.</em></p>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Example 1:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> word1 = "abc", word2 = "bca"
 | |
| <strong>Output:</strong> true
 | |
| <strong>Explanation:</strong> You can attain word2 from word1 in 2 operations.
 | |
| Apply Operation 1: "a<u>bc</u>" -> "a<u>cb</u>"
 | |
| Apply Operation 1: "<u>a</u>c<u>b</u>" -> "<u>b</u>c<u>a</u>"
 | |
| </pre>
 | |
| 
 | |
| <p><strong>Example 2:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> word1 = "a", word2 = "aa"
 | |
| <strong>Output:</strong> false
 | |
| <strong>Explanation: </strong>It is impossible to attain word2 from word1, or vice versa, in any number of operations.
 | |
| </pre>
 | |
| 
 | |
| <p><strong>Example 3:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> word1 = "cabbba", word2 = "abbccc"
 | |
| <strong>Output:</strong> true
 | |
| <strong>Explanation:</strong> You can attain word2 from word1 in 3 operations.
 | |
| Apply Operation 1: "ca<u>b</u>bb<u>a</u>" -> "ca<u>a</u>bb<u>b</u>"
 | |
| <code>Apply Operation 2: "</code><u>c</u>aa<u>bbb</u>" -> "<u>b</u>aa<u>ccc</u>"
 | |
| Apply Operation 2: "<u>baa</u>ccc" -> "<u>abb</u>ccc"
 | |
| </pre>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Constraints:</strong></p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>1 <= word1.length, word2.length <= 10<sup>5</sup></code></li>
 | |
| 	<li><code>word1</code> and <code>word2</code> contain only lowercase English letters.</li>
 | |
| </ul>
 |