字符串中最接近元音的距离 - JavaScript


我们需要编写一个 JavaScript 函数,它接受一个至少含有一个元音的字符串,并且我们必须为字符串中的每个字符绘制一个数字,表示其离元音的最近距离。

例如:如果字符串为

const str = 'vatghvf';

则输出应为

const output = [1, 0, 1, 2, 3, 4, 5];

示例

以下为代码

const str = 'vatghvf';
const nearest = (arr = [], el) => arr.reduce((acc, val) => Math.min(acc,
Math.abs(val - el)), Infinity);
const vowelNearestDistance = (str = '') => {
   const s = str.toLowerCase();
   const vowelIndex = [];
   for(let i = 0; i < s.length; i++){
      if(s[i] === 'a' || s[i] === 'e' || s[i] === 'i' || s[i] === 'o' ||
      s[i] === 'u'){
         vowelIndex.push(i);
      };
   };
   return s.split('').map((el, ind) => nearest(vowelIndex, ind));
};
console.log(vowelNearestDistance(str));

输出

以下是控制台中的输出

[
   1, 0, 1, 2,
   3, 4, 5
]

更新于: 2020 年 9 月 16 日

416 次浏览

启动你的 职业生涯

完成课程获得认证

开始
广告
© . All rights reserved.