全排列 & 任意排列 & 任意组合 & 笛卡尔积 算法

排列和组合的区别:

  • 排列:要求顺序,比如 [1,2] 和 [2,1] 是两个不同的排列
  • 组合:不要求顺序,比如 [1,2] 和 [2,1] 是两个相同的组合

全排列:

  • 给定n个数,返回长度为n的所有排列
  • 比如 [1,2,3] 的全排列是 [[1 2 3] [1 3 2] [2 1 3] [2 3 1] [3 1 2] [3 2 1]]
  • 可采用回溯法,遍历n叉树,得到所有路径

任意长度的排列:

  • 给定n个数,返回任意长度的所有排列
  • 比如 [1,2,3] 的任意长度的排列是 [[1] [1 2] [1 2 3] [1 3] [1 3 2] [2] [2 1] [2 1 3] [2 3] [2 3 1] [3] [3 1] [3 1 2] [3 2] [3 2 1]]
  • 可采用回溯法,遍历n叉树,得到所有路径
  • 和全排列的区别在于,路径长度可以为任意长度

组合:

  • 给定n个数,和长度 m,返回长度为m的所有组合
  • 比如 [1,2,3] 的长度为2的所有组合是 [[2 1] [3 1] [3 2]]
  • 可想象为先从数组里取1个数,然后从剩余的 n-1 个数里取出 m-1 长度的所有组合,进而得到所有组合

笛卡尔积:

  • 给定n个数组,每个数组取一个元素,返回长度为n的所有元素组合
  • 比如 [[1, 2], [3, 4]] 的笛卡尔积是 [1, 3] [1 4] [2 3] [2 4]
  • 比如 [[1, 2], [3, 4],
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值