提交记录 14219


用户 题目 状态 得分 用时 内存 语言 代码长度
jianglin router32. 测测你的路由器 Wrong Answer 25 9.694 ms 9716 KB C++ 1.27 KB
提交时间 评测时间
2020-09-18 17:26:44 2020-09-18 17:26:50
#include "router.h"
#include <arpa/inet.h>
struct RoutingTableNode {
    RoutingTableNode *nx[2];
    bool hasRoute;
    unsigned int nexthop;
    RoutingTableNode() {
        nx[0] = nx[1] = nullptr;
        hasRoute = false;
    }
} *root = nullptr;
void init(int n, int q, const RoutingTableEntry *a) {
    root = new RoutingTableNode();
    for (int i = 0; i < n; i++) {
        RoutingTableNode *now = root;
        unsigned int addr = htonl(a[i].addr);
        for (int i = 0; i < a[i].len; i++) {
            int nw = (addr & 0x80000000) != 0 ;
            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 = htonl(addr);
    RoutingTableNode *found = nullptr;
    if (now->hasRoute) {
        found = now;
    }
    for (int i = 0; i < 32; i++) {
        int nw = (addr & 0x80000000) != 0;
        addr <<= 1;
        if (!now->nx[nw]) {
            break;
        }
        now = now->nx[nw];
        if (now->hasRoute) {
            found = now;
        }
    }
    if (!found) {
        return 0;
    }
    return found->nexthop;
}

CompilationN/AN/ACompile OKScore: N/A

Testcase #110.91 us24 KBAcceptedScore: 25

Testcase #23.012 ms9 MB + 500 KBWrong AnswerScore: 0

Testcase #36.362 ms9 MB + 500 KBWrong AnswerScore: 0

Testcase #49.694 ms9 MB + 500 KBWrong AnswerScore: 0


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