gpt4 book ai didi

c# - 带有 IEnumerable 键的 LINQ OrderBy

转载 作者:行者123 更新时间:2023-12-04 00:33:16 24 4
gpt4 key购买 nike

我有一个 IEnumerable,我不想在每个序列中排序,而是从序列到序列排序。

new [] {"Z", "B", "C" }
new [] {"A", "B", "C" }
new [] {"B", "B", "C" }

变成了

new [] {"A", "B", "C" }
new [] {"B", "B", "C" }
new [] {"Z", "B", "C" }

是否有现有的 LINQ 方法,或者我是否需要推出自己的 IComparer?

最佳答案

没有内置任何内容。可以很简单地推出自己的辅助方法;它是一行只要序列长度相同

static int SequenceCompare<T>(
this IEnumerable<T> x,
IEnumerable<T> y,
Func<T, T, int> comparer) =>
x.Zip(y, comparer).FirstOrDefault(c => c != 0);

现在,如果您可以比较序列的两个成员,那么您也可以比较两个序列。

如果序列长度不等,则此方法不起作用;你必须做更多的工作才能说“A”,“B”,“C”比“A”,“B”“更大”。

练习:解决不等长序列的问题。 (提示:检查 Zip 的实现并进行相应修改。)

练习:假设我们有一个比较函数Func<T, T, int> 。我们已经了解了如何将其扩展到 Func<IEnumerable<T>, IEnumerable<T>, int> 。现在假设参数是 Task<T> ,或Func<T>Nullable<T>Lazy<T> ——您如何类似地进行比较?哪些是容易的,哪些是困难的,为什么?

关于c# - 带有 IEnumerable<T> 键的 LINQ OrderBy,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50242189/

24 4 0