gpt4 book ai didi

algorithm - 如何将递增序列号流压缩为一个?

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:02:04 25 4
gpt4 key购买 nike

我正在收听一个服务器,该服务器向我发送带有序列号的某些消息。我的客户端解析出序列号以跟踪我们是否得到重复项或是否遗漏序列号,尽管它通常由需要单个递增序列号的包装器对象调用。不幸的是,这个特定的服务器发送不同的序列号流,仅在每个子流中递增。换句话说,一个更简单的服务器会发送给我:

1,2,3,4,5,7

我会报告 1,2,3,4,5,6,7 并且包装器工具会通知丢失了一条消息。不幸的是,这个更复杂的服务器向我发送了类似的内容:

A1,A2,A3,B1,B2,A4,C1,A5,A7

(除了字母实际上也是数字代码,很方便)。上面除了A6没有空隙,但是由于需要报一个数给wrapper对象,所以报不了:

1,2,3,1,2,4,1,5,7

因为那会被错误地解释。因此,我想在我的客户中将我收到的内容压缩成一个单一的增量数字流。例子

A1,A2,A3,B1,B2,A4,C1,A5,A7

应该真的翻译成这样:

1,2,3,4(因为 B1 实际上是第 4 个唯一消息),5,6,7,8,10(因为 9 可能是 A6、B3、C2 或另一个字母 1)

然后这将被视为错过了一条消息 (A6)。另一个示例序列:

A1,A2,B1,A7,C1,A8

可以报告为:

1,2,3,8,9,10

因为前三个在逻辑上是有效的序列,没有任何遗漏。然后我们得到 A7,这意味着我们错过了 4 条消息(A3、A4、A5 和 A6),所以我返回 8 条消息,以便包装器可以判断。然后 C1 进来了,这很好,所以我给它 #9,然后 A8 现在是下一个预期的 A,所以我给它 10。

不过,我很难找到创建这种行为的方法。有哪些方法可以解决?

最佳答案

对于每个流,确保该流具有正确的顺序。然后,将您看到的所有有效序列号的计数作为合计发出。伪代码:

function initialize()
for stream in streams do
stream = 0
aggregateSeqno = 0

function process(streamId, seqno)
if seqno = streams[streamId] then
streams[streamId] = seqno + 1
aggregateSeqno = aggregateSeqno + 1
return aggregateSeqno
else then
try to fix streams[streamId] by replying to the server

function main()
initialize()
while(server not finished) do
(streamId, seqno) = receive()
process(streamId, seqno)

关于algorithm - 如何将递增序列号流压缩为一个?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14269391/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com