- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图借助几个例子来理解递归。我发现这个示例使用递归打印给定大小 n
数组中的 r
元素的所有可能组合。
Print all possible combinations of r elements in a given array of size n.
他们正在使用表达式背后的想法:
我在这里试图理解的是这个表达式的概念含义。我读过不同的文章,但找不到令人满意的解释。
使用此表达式的数学或实际示例将非常有帮助。
最佳答案
首先,数学中的组合有不同的表示法:
使用第一个,你的公式是
它的左侧表示:我们可以从n
个元素集中选择r
个元素的方式数量。
令S
为一组n
元素。令x
为它的最后一个元素,因此集合S
例如为
+-------------+---+
| a b c d e f | x |
+-------------+---+
设C
是集合S
中r
元素的任意组合。
(特别是,按照刚刚介绍的示例,您可以想象 r = 3
和 n = 7
- 因为集合是 {a, b 、c、d、e、f、x}
。)
只有两种可能:
C
包含 x
(例如 C = {a, d, x}
),或C
不包含 x
(例如 C = {a, d, e}
)。如果 C
包含 x
,则剩余的 (r - 1)
元素(即我们示例中的 2
) 是从剩余的 (n - 1)
元素中选择的(即我们示例中的 {a, b, c, d, e, f}
) - 所以有
如何选择这种组合的方法。
如果 C
不包含 x
,则从剩余 ( n - 1)
个元素 - 所以有
如何选择这种组合的方法。
关于java - 了解使用数组中所有可能组合的递归,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54655098/
降本手段一招鲜,增效方法吃遍天; 01 互联网行业里; 降本策略千奇百怪,手段却出奇一致;增效方法五花八门,手段更是花里胡哨; 对于企业来说;
有什么方法可以使用 angularjs 中的部分进行代码分组吗? 原因 --- 我的 Controller 包含太多代码。该 Controller 包含了多个方法和大量功能的代码,降低了代码的可读性。
不幸的是,我的数据库的数据模型必须改变,所以我正在寻找最轻松的方式来迁移我的数据。 此时情况如何: create table cargo{ id serial primary key, per
在 QTextEdit 对象中,假设我想知道字符在鼠标光标下的位置。 我会写... void MyQTextEditObject::mousePressEvent(QMouseEvent* mouse
是否可以在 C++ 中返回一个 return 语句或做一些具有类似功能的事情? 例如,如果代码中有几个函数将指针作为输入,并且每个函数都检查指针是否为 nullptr,这将很方便。如果它是一个 nul
我的 PC 上有一个控制台应用程序,它是 signalR 服务器。 我有一个 html 页面,它是互联网上的 signalR 客户端。但我尝试连接服务器,但我有一个错误的请求 400 错误。如果服务器
我想将应用程序作为后台进程运行。当点击应用程序图标时,它不会显示任何 View ,只会启动后台进程。 最佳答案 对于 iOS 这是不可能的,但是对于 android,react native 有 he
我知道有(昂贵的)框架可以让你在 VS C# 中编写 android 应用程序并将其编译为 android apk。 我也知道,可以在 VS 中编写 Java 应用程序(link)。 是否有可能,甚至
我在做: can :manage, :all if user.role == 'admin' can :approve, Anuncio do |anuncio| anuncio.try(:apr
我是一名优秀的程序员,十分优秀!