我正在尝试压缩两个不同长度的可观察序列,但我希望组合序列具有最大序列的长度,用最短序列的最后一个值填充。
也就是说,如果序列1是[0,1,2]而序列2是[0,1,2,3],我希望结果是[(0,0),(1,1) ,(2,2),(2,3)]。
我试图想办法用Zip或CombineLatest这样的现有运算符来实现它,但它实际上似乎比初看起来有点棘手。
答案 0 :(得分:2)
根据Enigmativity的想法,这是我的尝试:
aSource.Publish(ap => bSource.Publish(bp =>
{
var lastA = ap.TakeLast(1).Replay();
var lastB = bp.TakeLast(1).Replay();
var lastAForEachB = bp.SelectMany(b => lastA);
var lastBForEachA = ap.SelectMany(a => lastB);
var aWithLengthB = ap.Concat(lastAForEachB);
var bWithLengthA = bp.Concat(lastBForEachA);
lastA.Connect();
lastB.Connect();
return aWithLengthB.Zip(bWithLengthA, (a, b) => new { a, b });
}));