1790仅执行一次字符串交换能否使两个字符串相等
    题目:
    给你长度相等的两个字符串 s1 和 s2 。一次 字符串交换 操作的步骤如下:选出某个字符串中的两个下标(不必不同),并交换这两个下标所对应的字符。

    如果对 其中一个字符串 执行 最多一次字符串交换 就可以使两个字符串相等,返回 true ;否则,返回 false 。


    实例:
    示例 1:
    输入:s1 = “bank”, s2 = “kanb”
    输出:true
    解释:例如,交换 s2 中的第一个和最后一个字符可以得到 “bank”

    示例 2:
    输入:s1 = “attack”, s2 = “defend”
    输出:false
    解释:一次字符串交换无法使两个字符串相等


    题解:

    1. class Solution {
    2. public:
    3. bool areAlmostEqual(string s1, string s2) {
    4. if(s1==s2) return true;
    5. if(s1.size()!=s2.size()) return false;
    6. vector<int> temp;
    7. for(int i=0;i<s1.size();i++)
    8. {
    9. if(s1[i]!=s2[i])
    10. temp.push_back(i);
    11. }
    12. if(temp.size()==2&&s1[temp[0]]==s2[temp[1]]&&s1[temp[1]]==s2[temp[0]])
    13. return true;
    14. return false;
    15. }
    16. };