考慮以下幾點:LINQ和遞歸
public class Box
{
public BoxSize Size { get; set; }
public IEnumerable<Box> Contents { get; set; }
}
Box FindBoxBySize(Box box, BoxSize size)
{
Box _foundBox = null;
Action<IEnumerable<Box>> _recurse = null;
_recurse = new Action<IEnumerable<Box>>(boxes =>
{
foreach (var _box in boxes)
{
if (_box.Size == size)
{
_foundBox = _box;
return;
}
if (_box.Contents != null) _recurse(_box.Contents);
}
});
_recurse(box.Contents);
return _foundBox;
}
有沒有什麼辦法可以FindBoxBySize()
使用LINQ被壓縮?另外:歡迎對我的代碼發表評論。我沒有做太多的遞歸,所以我可能在我的實現中遺漏了一些東西。
我認爲它的確如此。但請注意我的訣竅;我真的很喜歡那裏儘可能少的「循環」,所以無論何時找到一場比賽,我想終止。 – roosteronacid 2010-11-23 14:49:00