提交记录 10440
| 提交时间 |
评测时间 |
| 2019-09-18 09:56:53 |
2020-08-01 02:14:41 |
#include "router.h"
#include <arpa/inet.h>
int reusei=0, reusej=0;
struct pp {pp* left, *right; unsigned refer;} pool[9999999]; int ppcnt=0; pp* reusep;
pp* insert(pp*& pos) {if(!pos){if(reusej<=reusei){pos=reusep+reusej++; pos->left=pos->right=0;pos->refer=0;}else pos=pool+ ++ppcnt; }return pos;}
pp& insert(int depth, unsigned pos) {pp* p=pool; for(int i=0; i<depth;++i) {
p=insert(pos&0x80000000?p->right:p->left), pos<<=1;
}
return *p;
}
void init(int n, int q, const RoutingTableEntry *a) { reusep=(pp*)a;
for(reusei=0; reusei<n; ++reusei) {unsigned t=a[reusei].nexthop; insert(a[reusei].len,htonl(a[reusei].addr)).refer=t;}
}
unsigned query(unsigned addr) {addr=htonl(addr);
unsigned res=0;pp* p=pool;
do {
if(p->refer)res=p->refer;p=addr&0x80000000?p->right:p->left;
addr<<=1;
}
while(p);return res;
}
| Compilation | N/A | N/A | Compile OK | Score: N/A | 显示更多 |
| Testcase #1 | 13.45 us | 32 KB | Accepted | Score: 25 | 显示更多 |
| Testcase #2 | 17.869 ms | 9 MB + 508 KB | Wrong Answer | Score: 0 | 显示更多 |
| Testcase #3 | 87.252 ms | 9 MB + 508 KB | Wrong Answer | Score: 0 | 显示更多 |
| Testcase #4 | 157.168 ms | 9 MB + 508 KB | Wrong Answer | Score: 0 | 显示更多 |
Judge Duck Online | 评测鸭在线
Server Time: 2026-03-29 12:48:20 | Loaded in 1 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠