monsoon
V2EX  ›  算法

有没有什么简单、性能也还过得去的 匹配 CIDR 集合(包含 IPv6 的 CIDR)的算法推荐?

  •  
  •   monsoon · May 27, 2020 · 2157 views
    This topic created in 2197 days ago, the information mentioned may be changed or developed.

    需求很简单的,就是有一个 1W 个左右的 CIDR 集合(包括 IP 、CIDR ),想匹配一个 IP 在不在这里面。宿主语言是 Java 之类不直接操作指针的语言。输入结果是一个 true 或者 false 就可以了。 现在我只会 loop 的方法和 binary trie…… IPv6 和 IPv4 我会分成两个集合分开来匹配就可以了。

    找了一下论文,感觉有很多的 Longest prefix match 的算法,但是不知道哪个改起来合适……写起来简单,性能也还可以,内存占用也不太。

    大家有没有什么推荐的算法,不要那种要 128 次匹配(对于 IPv6 )的那种。先谢谢了。

    3 replies    2020-05-28 20:40:29 +08:00
    rrfeng
        1
    rrfeng  
       May 27, 2020 via Android   ❤️ 1
    cidr ?要想快直接变数值,然后算出边界来直接比大小啊……简单写个二分查找就不会很差吧
    Erskine
        2
    Erskine  
       May 28, 2020 via Android   ❤️ 1
    统统转成 u128,然后排序 二分查找,最快
    monsoon
        3
    monsoon  
    OP
       May 28, 2020
    非常感谢楼上两位,转换成了一个 pair (表示 range ) 的 list,二分法非常好写。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3742 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 10:29 · PVG 18:29 · LAX 03:29 · JFK 06:29
    ♥ Do have faith in what you're doing.