1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 | using System; using System.Collections.Generic; using System.Linq; static class Program { public static void Main(string[] args) { var list1 = new int?[] {1, 2, 3, 4, 5}; var list2 = new int?[] {3, 4, 5, 6, 7}; var list3 = new int?[] {6, 9, 9}; var lockstep = LockStepSequences(new[] {list1, list2, list3}); foreach (var step in lockstep) Console.WriteLine(string.Join("\t", step.Select(i => i.HasValue? i.Value.ToString() : "null").ToArray())); } public static IEnumerable<IEnumerable<T>> LockStepSequences<T>(this IEnumerable<IEnumerable<T>> sequences) { var iters = sequences .Select((s, index) => new {index, enumerator = s.GetEnumerator()}) .Where(it => it.enumerator.MoveNext()) .ToArray(); try { for(var active = iters.ToList(); active.Any();) { T min = active.Min(it => it.enumerator.Current); var corresponding = active.Where(it => Equals(it.enumerator.Current, min)); yield return iters.Select((el, i) => corresponding.Any(it => it.index == i) ? el.enumerator.Current : default(T)); active = active.Except(corresponding.Where(it => !it.enumerator.MoveNext())).ToList(); } } finally { foreach (var iter in iters) iter.enumerator.Dispose(); } } } |
dXNpbmcgU3lzdGVtOwp1c2luZyBTeXN0ZW0uQ29sbGVjdGlvbnMuR2VuZXJpYzsKdXNpbmcgU3lzdGVtLkxpbnE7CgpzdGF0aWMgY2xhc3MgUHJvZ3JhbQp7CiAgICAgICAgcHVibGljIHN0YXRpYyB2b2lkIE1haW4oc3RyaW5nW10gYXJncykKICAgICAgICB7CiAgICAgICAgICAgIHZhciBsaXN0MSA9IG5ldyBpbnQ/W10gezEsIDIsIDMsIDQsIDV9OwogICAgICAgICAgICB2YXIgbGlzdDIgPSBuZXcgaW50P1tdIHszLCA0LCA1LCA2LCA3fTsKICAgICAgICAgICAgdmFyIGxpc3QzID0gbmV3IGludD9bXSB7NiwgOSwgOX07CgogICAgICAgICAgICB2YXIgbG9ja3N0ZXAgPSBMb2NrU3RlcFNlcXVlbmNlcyhuZXdbXSB7bGlzdDEsIGxpc3QyLCBsaXN0M30pOwoKICAgICAgICAgICAgZm9yZWFjaCAodmFyIHN0ZXAgaW4gbG9ja3N0ZXApCiAgICAgICAgICAgICAgICBDb25zb2xlLldyaXRlTGluZShzdHJpbmcuSm9pbigiXHQiLCBzdGVwLlNlbGVjdChpID0+IGkuSGFzVmFsdWU/IGkuVmFsdWUuVG9TdHJpbmcoKSA6ICJudWxsIikuVG9BcnJheSgpKSk7CiAgICAgICAgfQoKICAgICAgICBwdWJsaWMgc3RhdGljIElFbnVtZXJhYmxlPElFbnVtZXJhYmxlPFQ+PiBMb2NrU3RlcFNlcXVlbmNlczxUPih0aGlzIElFbnVtZXJhYmxlPElFbnVtZXJhYmxlPFQ+PiBzZXF1ZW5jZXMpCiAgICAgICAgewogICAgICAgICAgICB2YXIgaXRlcnMgPSBzZXF1ZW5jZXMKICAgICAgICAgICAgICAgIC5TZWxlY3QoKHMsIGluZGV4KSA9PiBuZXcge2luZGV4LCBlbnVtZXJhdG9yID0gcy5HZXRFbnVtZXJhdG9yKCl9KQogICAgICAgICAgICAgICAgLldoZXJlKGl0ID0+IGl0LmVudW1lcmF0b3IuTW92ZU5leHQoKSkKICAgICAgICAgICAgICAgIC5Ub0FycmF5KCk7CgogICAgICAgICAgICB0cnkKICAgICAgICAgICAgewogICAgICAgICAgICAgICAgZm9yKHZhciBhY3RpdmUgPSBpdGVycy5Ub0xpc3QoKTsgYWN0aXZlLkFueSgpOykKICAgICAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgICAgICBUIG1pbiA9IGFjdGl2ZS5NaW4oaXQgPT4gaXQuZW51bWVyYXRvci5DdXJyZW50KTsKICAgICAgICAgICAgICAgICAgICB2YXIgY29ycmVzcG9uZGluZyA9IGFjdGl2ZS5XaGVyZShpdCA9PiBFcXVhbHMoaXQuZW51bWVyYXRvci5DdXJyZW50LCBtaW4pKTsKCiAgICAgICAgICAgICAgICAgICAgeWllbGQgcmV0dXJuIGl0ZXJzLlNlbGVjdCgoZWwsIGkpID0+IGNvcnJlc3BvbmRpbmcuQW55KGl0ID0+IGl0LmluZGV4ID09IGkpCiAgICAgICAgICAgICAgICAgICAgICAgID8gZWwuZW51bWVyYXRvci5DdXJyZW50IAogICAgICAgICAgICAgICAgICAgICAgICA6IGRlZmF1bHQoVCkpOwoKICAgICAgICAgICAgICAgICAgICBhY3RpdmUgPSBhY3RpdmUuRXhjZXB0KGNvcnJlc3BvbmRpbmcuV2hlcmUoaXQgPT4gIWl0LmVudW1lcmF0b3IuTW92ZU5leHQoKSkpLlRvTGlzdCgpOwogICAgICAgICAgICAgICAgfQogICAgICAgICAgICB9CiAgICAgICAgICAgIGZpbmFsbHkKICAgICAgICAgICAgewogICAgICAgICAgICAgICAgZm9yZWFjaCAodmFyIGl0ZXIgaW4gaXRlcnMpIGl0ZXIuZW51bWVyYXRvci5EaXNwb3NlKCk7CiAgICAgICAgICAgIH0KICAgICAgICB9Cn0KCg==
-
upload with new input
-
result: Success time: 0.06s memory: 34272 kB returned value: 0
1
1 null null 2 null null 3 3 null 4 4 null 5 5 null null 6 6 null 7 null null null 9 null null 9
-
result: Success time: 0.06s memory: 37320 kB returned value: 0
1 null null 2 null null 3 3 null 4 4 null 5 5 null null 6 6 null 7 null null null 9 null null 9


