javascript - Palindrome:寻找最短的字符串
问题描述
任务如下:“编写一个 JavaScript 程序来找到最短的字符串,该程序可以创建一个字符串,通过在其末尾添加字符使其成为回文。”
这是我正在查看的代码:
function build_Palindrome(new_str) {
var flag;
for (var i = new_str.length;; i++) {
flag = true;
for (var j = 0; j < i - j - 1; j++) {
if (i - j - 1 < new_str.length && new_str[j] != new_str[i - j - 1]) {
flag = false;
break;
}
}
if (flag) {
for (var j = new_str.length; j < i; j++) {
new_str += new_str[i - j - 1];
}
return new_str;
}
}
}
测试:
console.log(build_Palindrome("abcddc"))
输出:
abcddcba
我的问题:起初它以j=0
. 如果在for
循环中flag=false
,那么它是如何进行的?是i=7
(i++
?)和是j=0
或j=1
?
解决方案
是的,您可以使用console.log或任何调试器进行调试。
对于您的情况,如果标志为假,它将中断j的循环并转到其外循环(此处为i)
我在这里做了演示: https ://repl.it/repls/LoyalProfuseRouter
您可以看到演示(它与我的解决方案一起提供),您可以使用简单的循环来返回您的字符串,而不是 break,它更具可读性。
推荐阅读
- python - 使用 Python 将文本文件中的网站 URL 迭代到 BeautifulSoup
- javascript - 如何使用 JS 在单击 SVG 矩形上添加文本
- swift - Firebase 远程配置不更新值?
- reactjs - multipart/form-data post api 适用于邮递员,但不能按预期从本机反应
- syncfusion - 使用 Syncfusion Circular Gauge 静态注入错误来了
- python - 在熊猫df中转置多行数据
- javascript - 如何创建两个单独的列表并显示它们?
- wordpress - Docker本地环境自定义本地域(hosts文件?)
- ios - 从 Xamarin.Form 将 iOS 构建提交到 Facebook
- angular7 - ngModel 不使用 ngx-material-timepicker 中的 value 属性并在 Angular7 中输入?