给你两个字符串 a 和 b ,它们长度相同。请你选择一个下标,将两个字符串都在 相同的下标 分割开。由 a 可以得到两个字符串: aprefix 和 asuffix ,满足 a = aprefix + asuffix ,同理,由 b 可以得到两个字符串 bprefix 和 bsuffix ,满足 b = bprefix + bsuffix 。请你判断 aprefix + bsuffix 或者 bprefix + asuffix 能否构成回文串。
当你将一个字符串 s 分割成 sprefix 和 ssuffix 时, ssuffix 或者 sprefix 可以为空。比方说, s = "abc" 那么 "" + "abc" , "a" + "bc" , "ab" + "c" 和 "abc" + "" 都是合法分割。
如果 能构成回文字符串 ,那么请返回 true,否则返回 false 。
注意, x + y 表示连接字符串 x 和 y 。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 | class Solution { public : bool checkPalindromeFormation(string a, string b) { if (isHuiwen(a) || isHuiwen(b)) { return true ; } int lenA = a.length(); int lenB = b.length(); for ( int i = 0;i <= lenA;++i) { string strA_pre = a.substr(0,i); string strA_suf = a.substr(i,lenA-i); string strB_pre = b.substr(0,i); string strB_suf = b.substr(i,lenB-i); // cout << strA_pre+strB_suf << " " << strA_suf+strB_pre << endl; if (isHuiwen(strA_pre+strB_suf) || isHuiwen(strB_pre+strA_suf)) { return true ; } } return false ; } bool isHuiwen(string a) { int len = a.length(); if (len == 0 || len == 1) { return true ; } for ( int i = 0;i < len;++i) { if (a[i] != a[len-i-1]) { return false ; } } return true ; } }; |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理