★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址: http://www.javashuo.com/article/p-xflumqrx-me.html
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html
Strings A
and B
are K
-similar (for some non-negative integer K
) if we can swap the positions of two letters in A
exactly K
times so that the resulting string equals B
.git
Given two anagrams A
and B
, return the smallest K
for which A
and B
are K
-similar.github
Example 1:微信
Input: A = "ab", B = "ba" Output: 1
Example 2:app
Input: A = "abc", B = "bca" Output: 2
Example 3:ide
Input: A = "abac", B = "baca" Output: 2
Example 4:spa
Input: A = "aabc", B = "abca" Output: 2
Note:code
1 <= A.length == B.length <= 20
A
and B
contain only lowercase letters from the set {'a', 'b', 'c', 'd', 'e', 'f'}
若是能夠經過將 A
中的兩個小寫字母精確地交換位置 K
次獲得與 B
相等的字符串,咱們稱字符串 A
和 B
的類似度爲 K
(K
爲非負整數)。htm
給定兩個字母異位詞 A
和 B
,返回 A
和 B
的類似度 K
的最小值。 blog
示例 1:
輸入:A = "ab", B = "ba" 輸出:1
示例 2:
輸入:A = "abc", B = "bca" 輸出:2
示例 3:
輸入:A = "abac", B = "baca" 輸出:2
示例 4:
輸入:A = "aabc", B = "abca" 輸出:2
提示:
1 <= A.length == B.length <= 20
A
和 B
只包含集合 {'a', 'b', 'c', 'd', 'e', 'f'}
中的小寫字母。1 class Solution { 2 func kSimilarity(_ A: String, _ B: String) -> Int { 3 if A == B {return 0} 4 var arrB:[Character] = Array(B) 5 var vis:Set<String> = Set<String>() 6 var q:[String] = [String]() 7 q.append(A) 8 vis.insert(A) 9 var res:Int = 0 10 while(!q.isEmpty) 11 { 12 res += 1 13 for sz in stride(from:q.count,to:0,by:-1) 14 { 15 var s:String = q.removeFirst() 16 var arrS:[Character] = Array(s) 17 var i:Int = 0 18 while(arrS[i] == arrB[i]) 19 { 20 i += 1 21 } 22 for j in (i + 1)..<s.count 23 { 24 if arrS[j] == arrB[j] || arrS[i] != arrB[j] 25 { 26 continue 27 } 28 var temp:String = swap(s, i, j) 29 if temp == B {return res} 30 if !vis.contains(temp) 31 { 32 vis.insert(temp) 33 q.append(temp) 34 } 35 } 36 } 37 } 38 return res 39 } 40 41 func swap(_ s:String,_ i:Int,_ j:Int) -> String 42 { 43 var arrS:[Character] = Array(s) 44 arrS.swapAt(i,j) 45 return String(arrS) 46 } 47 }