В .NET существует ли подобный zip метод?

В Java все находится в форме класса.

Если вы хотите использовать любой объект, тогда у вас есть две фазы:

  1. Объявить
  2. Инициализация

Пример:

  • Объявление: Object a;
  • Инициализация: a=new Object();

То же самое для концепции массива

  • Объявление: Item i[]=new Item[5];
  • Инициализация: i[0]=new Item();

Если вы не дают секцию инициализации, тогда возникает NullpointerException.

12
задан Jonas 17 November 2017 в 10:22
поделиться

4 ответа

Обновление: Это встроено в C# 4 как , Метод System.Linq.Enumerable.Zip

Вот является версией C# 3:

IEnumerable<TResult> Zip<TResult,T1,T2>
    (IEnumerable<T1> a,
     IEnumerable<T2> b,
     Func<T1,T2,TResult> combine)
{
    using (var f = a.GetEnumerator())
    using (var s = b.GetEnumerator())
    {
        while (f.MoveNext() && s.MoveNext())
            yield return combine(f.Current, s.Current);
    }
}

Отброшенный версия C# 2, поскольку это показывало свой возраст.

25
ответ дан 2 December 2019 в 03:43
поделиться

Насколько я знаю, что нет. Я записал один для меня (а также несколько других полезных расширений, и поместите их в проект, названный NExtension на Codeplex.

, По-видимому, Параллельные расширения для.NET имеют функцию Zip.

Вот упрощенная версия от NExtension (но проверьте его для более полезных дополнительных методов):

public static IEnumerable<TResult> Zip<T1, T2, TResult>(this IEnumerable<T1> source1, IEnumerable<T2> source2, Func<T1, T2, TResult> combine)
{
    using (IEnumerator<T1> data1 = source1.GetEnumerator())
    using (IEnumerator<T2> data2 = source2.GetEnumerator())
        while (data1.MoveNext() && data2.MoveNext())
        {
            yield return combine(data1.Current, data2.Current);
        }
}

Использование:

int[] list1 = new int[] {1, 2, 3};
string[] list2 = new string[] {"a", "b", "c"};

foreach (var result in list1.Zip(list2, (i, s) => i.ToString() + " " + s))
    Console.WriteLine(result);
8
ответ дан 2 December 2019 в 03:43
поделиться

Нет, в.NET нет такой функции. У Вас есть развертывание Ваше собственное. Обратите внимание, что C# не поддерживает кортежи, таким образом, подобный Python сахар синтаксиса отсутствует также.

можно использовать что-то вроде этого:

class Pair<T1, T2>
{
    public T1 First { get; set;}
    public T2 Second { get; set;}
}

static IEnumerable<Pair<T1, T2>> Zip<T1, T2>(IEnumerable<T1> first, IEnumerable<T2> second)
{
    if (first.Count() != second.Count())
        throw new ArgumentException("Blah blah");

    using (IEnumerator<T1> e1 = first.GetEnumerator())
    using (IEnumerator<T2> e2 = second.GetEnumerator())
    {
        while (e1.MoveNext() && e2.MoveNext())
        {
            yield return new Pair<T1, T2>() {First = e1.Current, Second = e2.Current};
        }
    }
}

...

var ints = new int[] {1, 2, 3};
var strings = new string[] {"A", "B", "C"};

foreach (var pair in Zip(ints, strings))
{
    Console.WriteLine(pair.First + ":" + pair.Second);
}
5
ответ дан 2 December 2019 в 03:43
поделиться

Существует также один в F#:

позволяют заархивированный = Seq.zip firstEnumeration secondEnumation

2
ответ дан 2 December 2019 в 03:43
поделиться
Другие вопросы по тегам:

Похожие вопросы: