用 JavaScript 过滤数组以包含回文元素


我们需要编写一个 JavaScript 函数,它获取一个字符串/数字字面量的数组,并返回原始数组中所有回文字符串的子数组。

例如

如果输入数组是 -

const arr = ['carecar', 1344, 12321, 'did', 'cannot'];

那么输出应为 -

const output = [12321, 'did'];

我们将创建一个帮助器函数,它获取一个数字或字符串并检查它是不是布尔值。

然后我们将遍历数组,过滤回文元素并返回过滤后的数组。

因此,让我们编写此函数的代码 -

示例

代码如下 -

const arr = ['carecar', 1344, 12321, 'did', 'cannot'];
const isPalindrome = el => {
   const str = String(el);
   let i = 0;
   let j = str.length - 1;
   while(i < j) {
      if(str[i] === str[j]) {
         i++;
         j--;
      } else {
         return false;
      }
   }
   return true;
};
const findPalindrome = arr => {
   return arr.filter(el => isPalindrome(el));
};
console.log(findPalindrome(arr));

输出

控制台中的输出将是 -

[ 12321, 'did' ]

更新于:2020-10-21

239 次浏览

开启你的职业生涯

完成课程获得认证

入门
广告