数组的操作(2)

简介: 1、使用递归。对于给定字符串中的每个字母,为字母创建字谜。使用map()将字母与每部分字谜组合,然后使用reduce()将所有字谜组合到一个数组中,最基本情况是字符串长度等于2或1。const anagrams = str => { if (str.

1、使用递归。对于给定字符串中的每个字母,为字母创建字谜。使用map()将字母与每部分字谜组合,然后使用reduce()将所有字谜组合到一个数组中,最基本情况是字符串长度等于2或1。

const anagrams = str => {

  if (str.length <= 2) return str.length === 2 ? [str, str[1] + str[0]] : [str];

  return str.split('').reduce((acc, letter, i) =>

    acc.concat(anagrams(str.slice(0, i) + str.slice(i + 1)).map(val => letter + val)), []);

};

// anagrams('abc') -> ['abc','acb','bac','bca','cab','cba']

// anagrams('读好书') -> ["读好书", "读书好", "好读书", "好书读", "书读好", "书好读"]
 

 相当于数据里的排列组合里面的 全排列 个数就是  arr.length ! 

 这里介绍一些 reduce  。

mdn说:

reduce() 方法对累加器和数组中的每个元素(从左到右)应用一个函数,将其减少为单个值。

var total = [0, 1, 2, 3].reduce(function(sum, value) {
  return sum + value;
}, 0);
// total is 6

var flattened = [[0, 1], [2, 3], [4, 5]].reduce(function(a, b) {
  return a.concat(b);
}, []);
// flattened is [0, 1, 2, 3, 4, 5]

可以简单理解对 数组的元素逐项做操作,下面是es6的写法

var flattened = [[0, 1], [2, 3], [4, 5]].reduce(
  ( acc, cur ) => acc.concat(cur),
  []
);

详细案例参考  https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/Reduce

 

更多有趣的数组操作: http://news.51cto.com/art/201712/561035.htm  

     https://mp.weixin.qq.com/s?__biz=MzAxODE2MjM1MA==&mid=2651553296&idx=1&sn=dcec2412f5b4bdeef4971fd0c96f3958&chksm=8025a9d1b75220c77a9784056bb69a54cfb4d41dcc9dae971e321ce0074747bc6dc054505ae3&mpshare=1&scene=23&srcid=1218kPR7PaP1ZqyIVoLHXfHH#rd

目录
相关文章
|
7月前
|
存储 C语言
|
3月前
关于数组的两个应用
关于数组的两个应用
30 0
关于数组的两个应用
|
8月前
|
存储 算法 计算机视觉
数组
数组
65 0
|
7月前
数组(2)
数组(2)
37 1
|
7月前
|
存储 开发框架 .NET
C#中的数组探索
C#中的数组探索
|
存储 C语言 索引
C 数组
C 数组。
45 0
|
8月前
|
存储 程序员 C++
|
8月前
|
存储 C++
C++-数组总结
C++-数组总结
51 0
|
存储 编译器 程序员
数组详解
数组详解
79 0
|
存储 程序员 C#
【总结】C#中的数组
【总结】C#中的数组