Ответ 1
Если вы используете .Net 3.5, Enumerable.Range - это то, что вам нужно.
Создает последовательность интегралов числа в пределах заданного диапазона.
Мне нужен список целых чисел от 1 до x, где x задается пользователем. Я мог бы построить его с циклом for, например, предполагая, что x является целым числом ранее:
List<int> iList = new List<int>();
for (int i = 1; i <= x; i++)
{
iList.Add(i);
}
Это кажется немым, конечно, более элегантный способ сделать это, что-то вроде метод диапазона PHP
Если вы используете .Net 3.5, Enumerable.Range - это то, что вам нужно.
Создает последовательность интегралов числа в пределах заданного диапазона.
LINQ на помощь:
// Adding value to existing list
var list = new List<int>();
list.AddRange(Enumerable.Range(1, x));
// Creating new list
var list = Enumerable.Range(1, x).ToList();
См. Операторы генерации на LINQ 101
Я один из многих, у кого в блоге о методе ruby-esque. Для расширения, который вы можете написать, если используете С# 3.0:
public static class IntegerExtensions
{
public static IEnumerable<int> To(this int first, int last)
{
for (int i = first; i <= last; i++)
{
yield return i;
}
}
}
Затем вы можете создать список целых чисел, например
List<int> = first.To(last).ToList();
или
List<int> = 1.To(x).ToList();
Вот короткий метод, который возвращает список целых чисел.
public static List<int> MakeSequence(int startingValue, int sequenceLength)
{
return Enumerable.Range(startingValue, sequenceLength).ToList<int>();
}