JavaScript 中的回文
回文是一个单词、数字、短语或其他可以前后阅读的字符序列,例如 adida
或 racecar
。还有数字回文,包括使用短数字的日期和时间戳。
例如,2011 年 11 月 11 日
被认为是回文日 111111
,使用 dd-mm-yy
格式,因为它可以从左到右阅读,反之亦然。句子长度回文忽略标点符号、大写字母和单词边界。
这篇文章教我们检查字符串/数字是否是 JavaScript 中的回文。
在 JavaScript 中使用内置函数进行回文运算
JavaScript 提供了几个函数,我们可以使用它们来检测字符串是否为回文。
- 首先,使用
string.split()
函数将字符串转换为数组。
split()
方法是 JavaScript 提供的内置方法。此方法将字符串拆分为子字符串列表。
通过将分隔符作为输入来执行此切割。
这个分隔符纯粹是一个可选的输入。并基于此,将所有这些子字符串放入一个数组中,并返回该数组。
你还可以将 limit 作为输入传递给该方法,从而限制数组中子字符串的数量。
- 其次,使用
reverse()
方法反转数组的值。
reverse()
方法是 JavaScript 提供的内置方法。此方法改为反转原始数组。
数组的第一个元素成为数组的最后一个元素,数组的最后一个元素成为第一个元素。
- 最后,使用
join()
方法将数组的值分组到字符串中。
join()
方法是 JavaScript 提供的内置方法。此方法通过连接数组(或类似数组的对象)中的所有元素创建并返回一个新字符串,由逗号或指定的分隔符字符串分隔。
如果数组只有一个元素,则返回该元素而不使用分隔符。
让我们结合上述所有方法并检查输入字符串是否为回文。
function palindromeFn(inputString) {
return inputString == inputString.split('').reverse().join('');
}
console.log(palindromeFn('aviddiva'))
console.log(palindromeFn('Hello'))
如果我们在任何浏览器中运行上述代码,它将显示以下结果。
输出:
"true"
"false"
带有 for
循环的 JavaScript 回文
检查字符串是否为回文的另一种方法是使用 for
循环。以下是在 JavaScript 中检查字符串是否为回文的步骤。
-
首先,取一个包含要检查的字符串长度的临时变量。
-
应用
for
循环并设置条件以检查字符串的一半长度。 -
将原始字符串字符与反转字符串字符进行比较。
-
如果前后字符相同,则字符串或数字为回文。否则,指定的字符串或数字不是回文。
function palindromeFn(string) {
const stringLength = string.length;
for (let i = 0; i < stringLength / 2; i++) {
if (string[i] !== string[stringLength - 1 - i]) {
return 'It is not a palindrome.';
}
}
return 'It is a palindrome.';
}
console.log(palindromeFn('aviddiva'));
console.log(palindromeFn('Hello'));
如果我们在任何浏览器中运行上述代码,它将显示以下结果。
输出:
"It is a palindrome."
"It is not a palindrome."
Shraddha is a JavaScript nerd that utilises it for everything from experimenting to assisting individuals and businesses with day-to-day operations and business growth. She is a writer, chef, and computer programmer. As a senior MEAN/MERN stack developer and project manager with more than 4 years of experience in this sector, she now handles multiple projects. She has been producing technical writing for at least a year and a half. She enjoys coming up with fresh, innovative ideas.
LinkedIn