You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Hydro/hydro/model/builtin.js

304 lines
7.0 KiB
JavaScript

const perm = require('../permission');
5 years ago
const BUILTIN_ROLES = {
guest: { perm: perm.PERM_BASIC },
default: { perm: perm.PERM_DEFAULT },
admin: { perm: perm.PERM_ADMIN },
};
4 years ago
const DEFAULT_NODES = {
探索: [
{ pic: 'qa', name: '问答' },
{ pic: 'share', name: '分享' },
{ pic: 'solution', name: '题解' },
],
Vijos: [
{ pic: 'vijos', name: 'Vijos' },
{ pic: null, name: '团队' },
{ pic: null, name: '月赛' },
{ pic: 'advice', name: '建议' },
],
数据结构: [
{ pic: null, name: '散列表' },
{ pic: null, name: '搜索树' },
{ pic: null, name: '栈和队列' },
{ pic: null, name: '图' },
{ pic: null, name: '堆' },
],
算法: [
{ pic: null, name: '数论' },
{ pic: null, name: '几何' },
{ pic: null, name: '图论' },
{ pic: null, name: '网络流' },
{ pic: null, name: '动态规划' },
{ pic: null, name: '背包' },
{ pic: null, name: '排序' },
{ pic: null, name: '搜索' },
{ pic: null, name: '并查集' },
{ pic: null, name: '贪心' },
{ pic: null, name: '博弈论' },
],
在线题库: [
{ pic: null, name: 'CodeForces' },
{ pic: null, name: 'TopCoder' },
{ pic: null, name: 'POJ' },
{ pic: null, name: 'BZOJ' },
{ pic: null, name: 'USACO' },
{ pic: null, name: 'RQNOJ' },
{ pic: null, name: 'UOJ' },
{ pic: null, name: 'LOJ' },
{ pic: null, name: '洛谷' },
],
: [
{ pic: null, name: '数学' },
{ pic: null, name: '编程' },
{ pic: null, name: '数据库' },
{ pic: null, name: 'C' },
{ pic: null, name: 'C++' },
{ pic: null, name: 'Pascal' },
{ pic: null, name: 'Java' },
{ pic: null, name: 'PHP' },
{ pic: null, name: 'Python' },
{ pic: null, name: '游戏' },
{ pic: null, name: '保送' },
{ pic: null, name: 'ACM' },
],
};
const CATEGORIES = {
5 years ago
动态规划: [
'LCS',
'LIS',
'背包',
'单调性DP',
'环形DP',
'树形DP',
5 years ago
'状态压缩DP',
],
5 years ago
搜索: [
'枚举',
'搜索与剪枝',
'启发式搜索',
'DLX',
'双向搜索',
'折半搜索',
'记忆化搜索',
5 years ago
'模拟退火',
],
5 years ago
计算几何: [
'半平面交',
'凸包',
'几何图形的交与并',
'旋转卡壳',
'点定位',
'坐标变换',
'离散化与扫描',
'反演',
'Voronoi图',
'平面图的对偶图',
'三角剖分',
'梯形剖分',
5 years ago
'几何知识',
],
5 years ago
贪心: [],
树结构: [
'最近公共祖先',
'生成树',
'DFS序列',
'树上倍增',
'树的分治',
'树链剖分',
5 years ago
'Link-Cut-Tree',
],
5 years ago
图结构: [
'平面图',
'二分图',
'二分图匹配',
'最短路',
'差分约束',
'拓扑排序',
'网络流',
'强连通分量',
'割点割边',
'欧拉回路',
5 years ago
'2-SAT',
],
5 years ago
数论: [
'素数判定',
'欧几里得算法',
'不定方程',
'数位统计',
'解线性同余方程',
'baby-step-giant-step',
'Pell方程',
'大整数质因数分解',
'勾股方程',
'积性函数',
5 years ago
'Fibonacci数列',
],
5 years ago
模拟: [],
数据结构: [
'栈',
'队列',
'链表',
'单调队列',
'并查集',
'堆',
'平衡树',
'线段树',
'树状数组',
'树套树',
'四分树',
'划分树',
'归并树',
'k-d树',
'块状链表',
'Hashing',
5 years ago
'函数式编程',
],
5 years ago
博弈论: [],
字符串: [
'KMP',
'后缀数据结构',
'Trie树',
'AC自动机',
'Manacher',
'表达式处理',
5 years ago
'最小表示法',
],
5 years ago
组合数学: [
'生成函数',
'容斥原理',
'康托展开',
'Catalan数列',
'Stirling数',
'差分',
5 years ago
'Polya定理',
],
5 years ago
线性代数: [
'矩阵乘法',
'高斯消元',
5 years ago
'线性规划',
],
5 years ago
高精度: [
'FFT',
],
5 years ago
递推: [],
概率论: [
'随机化',
],
5 years ago
NPC: [],
其他: [
'二分查找',
'三分查找',
'双指针扫描',
'分治',
'分块',
'RMQ',
'快速幂',
'数学',
'排序',
5 years ago
'构造',
],
};
const FOOTER_EXTRA_HTMLS = [];
const VIEW_LANGS = [
{ code: 'zh_CN', name: '简体中文' },
{ code: 'zh_TW', name: '正體中文' },
{ code: 'en', name: 'English' },
];
const LANG_TEXTS = {
c: 'C',
cc: 'C++',
cs: 'C#',
pas: 'Pascal',
java: 'Java',
py: 'Python',
py3: 'Python 3',
php: 'PHP',
rs: 'Rust',
hs: 'Haskell',
js: 'JavaScript',
go: 'Go',
rb: 'Ruby',
};
const LANG_HIGHLIGHT_ID = {
c: 'c',
cc: 'cpp',
cs: 'csharp',
pas: 'pascal',
java: 'java',
py: 'python',
py3: 'python',
php: 'php',
rs: 'rust',
hs: 'haskell',
js: 'javascript',
go: 'go',
rb: 'ruby',
};
const STATUS = {
STATUS_WAITING: 0,
STATUS_ACCEPTED: 1,
STATUS_WRONG_ANSWER: 2,
STATUS_TIME_LIMIT_EXCEEDED: 3,
STATUS_MEMORY_LIMIT_EXCEEDED: 4,
STATUS_OUTPUT_LIMIT_EXCEEDED: 5,
STATUS_RUNTIME_ERROR: 6,
STATUS_COMPILE_ERROR: 7,
STATUS_SYSTEM_ERROR: 8,
STATUS_CANCELED: 9,
STATUS_ETC: 10,
STATUS_JUDGING: 20,
STATUS_COMPILING: 21,
STATUS_FETCHED: 22,
5 years ago
STATUS_IGNORED: 30,
};
const STATUS_TEXTS = {
[STATUS.STATUS_WAITING]: 'Waiting',
[STATUS.STATUS_ACCEPTED]: 'Accepted',
[STATUS.STATUS_WRONG_ANSWER]: 'Wrong Answer',
[STATUS.STATUS_TIME_LIMIT_EXCEEDED]: 'Time Exceeded',
[STATUS.STATUS_MEMORY_LIMIT_EXCEEDED]: 'Memory Exceeded',
[STATUS.STATUS_OUTPUT_LIMIT_EXCEEDED]: 'Output Exceeded',
[STATUS.STATUS_RUNTIME_ERROR]: 'Runtime Error',
[STATUS.STATUS_COMPILE_ERROR]: 'Compile Error',
[STATUS.STATUS_SYSTEM_ERROR]: 'System Error',
[STATUS.STATUS_CANCELED]: 'Cancelled',
[STATUS.STATUS_ETC]: 'Unknown Error',
[STATUS.STATUS_JUDGING]: 'Running',
[STATUS.STATUS_COMPILING]: 'Compiling',
[STATUS.STATUS_FETCHED]: 'Fetched',
[STATUS.STATUS_IGNORED]: 'Ignored',
};
const STATUS_CODES = {
0: 'pending',
1: 'pass',
2: 'fail',
3: 'fail',
4: 'fail',
5: 'fail',
6: 'fail',
7: 'fail',
8: 'fail',
9: 'ignored',
10: 'fail',
20: 'progress',
21: 'progress',
22: 'progress',
5 years ago
30: 'ignored',
};
4 years ago
global.Hydro.model.builtin = module.exports = {
5 years ago
BUILTIN_ROLES,
4 years ago
DEFAULT_NODES,
5 years ago
CATEGORIES,
VIEW_LANGS,
FOOTER_EXTRA_HTMLS,
LANG_TEXTS,
LANG_HIGHLIGHT_ID,
STATUS,
STATUS_TEXTS,
STATUS_CODES,
};