C# 递归函数有助于理解它是如何工作的?
我需要帮助来理解函数是如何工作的;:它是一个带有yield return的递归函数,但我不知道它是如何工作的。它用于计算一组数据的累积
密度函数(近似值)。
非常感谢大家。
/// Approximates the cumulative density through a recursive procedure
/// estimating counts of regions at different resolutions.
/// </summary>
/// <param name="data">Source collection of integer values</param>
/// <param name="maximum">The largest integer in the resulting cdf (it has to be a power of 2...</param>
/// <returns>A list of counts, where entry i is the number of records less than i</returns>
public static IEnumerable<int> FUNCT(IEnumerable<int> data, int max)
{
if (max == 1)
{
yield return data.Count();
}
else
{
var t = data.Where(x => x < max / 2);
var f = data.Where(x => x > max / 2);
foreach (var value in FUNCT(t, max / 2))
yield return value;
var count = t.Count();
f = f.Select(x => x - max / 2);
foreach (var value in FUNCT(f, max / 2))
yield return value + count;
}
}
I need help to understand how a function is working;: it is a recursive
function with yield return but I can't figure out how it works. It is used calculate a cumulative
density function (approximate) over a set of data.
Thanks a lot to everyone.
/// Approximates the cumulative density through a recursive procedure
/// estimating counts of regions at different resolutions.
/// </summary>
/// <param name="data">Source collection of integer values</param>
/// <param name="maximum">The largest integer in the resulting cdf (it has to be a power of 2...</param>
/// <returns>A list of counts, where entry i is the number of records less than i</returns>
public static IEnumerable<int> FUNCT(IEnumerable<int> data, int max)
{
if (max == 1)
{
yield return data.Count();
}
else
{
var t = data.Where(x => x < max / 2);
var f = data.Where(x => x > max / 2);
foreach (var value in FUNCT(t, max / 2))
yield return value;
var count = t.Count();
f = f.Select(x => x - max / 2);
foreach (var value in FUNCT(f, max / 2))
yield return value + count;
}
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
从本质上讲,使用yield返回函数的IEnumerable函数与传统的递归函数略有不同。作为基本情况,假设您有:
F
采用原始FUNCT
的基本形式。如果我们调用 F(2),则遍历结果:并打印
1267
。请注意,yield return
语句将控制权交给调用者,但下一次迭代会导致函数在先前让出的位置继续执行。CDF 方法确实增加了一些额外的复杂性,但不多。递归将集合分成两部分,并计算每部分的 CDF,直到 max=1。然后该函数计算元素的数量并产生它,每个产生递归地传播到封闭循环。
要演练
FUNCT
,假设您使用data=[0,1,0,1,2,3,2,1]
和max=4< 运行/代码>。然后使用与上面相同的
Main
函数作为驱动程序运行该方法,结果如下:因此返回值 (2,2,5,5)。 (使用
>=
将产生值 (2,5,7,8) - 请注意,这些是非负积分数据的缩放 CDF 的精确值,而不是近似值) 。In essence, IEnumerable functions that use yield return function slightly differently from traditional recursive functions. As a base case, suppose you have:
F
takes the basic orm of the originalFUNCT
. If we call F(2), then walking through the yields:And
1267
is printed. Note that theyield return
statement yields control to the caller, but that the next iteration causes the function to continue where it had previously yielded.The CDF method does adds some additional complexity, but not much. The recursion splits the collection into two pieces, and computes the CDF of each piece, until max=1. Then the function counts the number of elements and yields it, with each yield propogating recursively to the enclosing loop.
To walk through
FUNCT
, suppose you run withdata=[0,1,0,1,2,3,2,1]
andmax=4
. Then running through the method, using the sameMain
function above as a driver, yields:So this returns the values (2,2,5,5). (using
>=
would yield the values (2,5,7,8) -- note that these are the exact values of a scaled CDF for non-negative integral data, rather than an approximation).有趣的问题。假设您了解 yield 的工作原理,该函数的注释(在您的问题)非常有帮助。我按照我的理解对代码进行了评论,这可能会有所帮助:
Interesting question. Assuming you understand how yield works, the comments on the function (in your question) are very helpful. I've commented the code as I understand it which might help: