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

标签 algorithm sequence sequences

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

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/

相关文章:

c++ - 从数据列表生成随机序列的最快方法是什么?

k个元素的计数序列

python - 获取整数中偶数最长序列的最佳方法

R +查找算法以匹配一系列相同元素内的值

algorithm - 查找长度为 3 的递增(或递减)子序列数?

algorithm - 如何计算32位整数中的设置位数?

f# - 在 F# 中缩放序列

php - 检查数组中的唯一值和非唯一值

r - 在 R 中生成具有交替增量的序列?

Python self[name] = value 是什么意思?