提交记录 14213


用户 题目 状态 得分 用时 内存 语言 代码长度
jianglin router32. 测测你的路由器 Compile Error 0 0 ns 0 KB C++ 1.65 KB
提交时间 评测时间
2020-09-18 16:21:14 2020-09-18 16:21:15
#include "router.h"
struct RoutingTableNode {
    RoutingTableNode *nx[2];
    bool hasRoute;
    unsigned int nexthop;
    RoutingTableNode() {
        nx[0] = nx[1] = nullptr;
        hasRoute = false;
    }
    ~RoutingTableNode() {
        if (nx[0]) {
            delete nx[0];
        }
        if (nx[1]) {
            delete nx[1];
        }
    }
} *root = nullptr;
void init(int n, int q, const RoutingTableEntry *a) {
    root = new RoutingTableNode;
    for (int i = 0; i < n; i++) {
        unsigned int addr = a[i].addr;
        addr = ((addr & 0xffff) << 16) | (addr >> 16); // 2143
        addr = ((addr & 0x00ff00ff) << 8) | ((addr & 0xff00ff00) >> 8); //1234
        for (int i = 0; i < a[i].len; i++) {
            bool nw = addr & 0x80000000;
            addr <<= 1;
            if (!now->nx[nw]) {
                now->nx[nw] = new RoutingTableNode;
            }
            now = now->nx[nw];
        }
        now->hasRoute = true;
        now->nexthop = a[i].nexthop;
    }
}

unsigned query(unsigned addr) {
    RoutingTableNode *now = root;
    addr = ((addr & 0xffff) << 16) | (addr >> 16); // 2143
    addr = ((addr & 0x00ff00ff) << 8) | ((addr & 0xff00ff00) >> 8); //1234
    RoutingTableNode *found = nullptr;
    if (now->hasRoute) {
        found = now;
    }
    for (int i = 0; i < 32; i++) {
        bool nw = addr & 0x80000000;
        addr <<= 1;
        if (!now->nx[nw]) {
            if (!found) {
                return 0;
            }
            return found->nexthop;
        }
        now = now->nx[nw];
        if (now->hasRoute) {
            found = now;
        }
    }
    if (!found) {
        return 0;
    }
    return found->nexthop;
}

CompilationN/AN/ACompile ErrorScore: N/A


Judge Duck Online | 评测鸭在线
Server Time: 2026-03-22 23:16:07 | Loaded in 1 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠