c# – 是否存在一个预先存在的函数,它将根据基数和“偏移量”返回一组数字?

前端之家收集整理的这篇文章主要介绍了c# – 是否存在一个预先存在的函数,它将根据基数和“偏移量”返回一组数字?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我不想重新发明轮子:如果我想从给定数字中得到N范围内的每个整数,那么最有效的方法是什么?

我的意思是这样的:

public List<int> getIntsWithinN(int BaseInt,int Offset)

…如果传入的args是7和3,结果将是4..10;如果传入的args是42和7,结果将是35..49等.

UPDATE

好的,我终于开始尝试实现这个了.但我不知道是否应该将我的List传递给ToList(),如下所示:

List<int> listInts = new List<int>();
. . .
Enumerable.Range(lineNum - Offset,Offset * 2 + 1).ToList(listInts);

……或者这样做:

listInts = Enumerable.Range(lineNum - Offset,Offset * 2 + 1).ToList();

…但我需要做的是多次调用,因此Intellisense描述看起来并不像我真正需要的那样.它说,“创建……列表…”

但我不希望每次都创建一个新的,我想要附加到现有的列表,并且最好同时忽略重复.

解决方法

preferably simultaneously disregarding duplicates

在那你应该考虑HashSet< int>.

var hashSet = new HashSet<int>();
hashSet.UnionWith(Enumerable.Range(lineNum - offset,offset * 2 + 1));

如果你想要一个列表,你可以在hashSet上调用ToList().您可能还希望在转换为列表时对其进行排序,因为HashSet< T>将项目保持在未定义的顺序.

var list = hashSet.OrderBy(i=>i).ToList();
原文链接:https://www.f2er.com/csharp/98298.html

猜你在找的C#相关文章