每个用户可以创建自己的域。比如,老师可以为课程创建一个域,然后把题目和学生加入到此域中。再如,可以把域作为团队功能。

通过合理的设置角色及其权限,可以把域设为公开或私有。

默认域为 system,用户直接访问 咕噜OJ 域名就会访问此域,点击 Hydro Logo 会从任意域跳转回 system 域。

每个域的题库、公告、训练以及比赛是独立且自治的。

编译器版本及参数

咕噜OJ 使用 HydroJudge 进行评测,编译参数如下:

  • Bash(bash)
    /bin/bash foo.sh
  • C(c)
    /usr/bin/gcc -Wall --std=c99 -o foo foo.c -lm
  • C++(cc)
    /usr/bin/g++ -Wall -std=c++14 -o foo foo.cc -lm -I/include -fdiagnostics-color=always
  • C++98(cc.cc98)
    /usr/bin/g++ -Wall -std=c++98 -o foo foo.cc -lm -I/include -fdiagnostics-color=always
  • C++98(O2)(cc.cc98o2)
    /usr/bin/g++ -Wall -std=c++98 -o foo foo.cc -lm -O2 -I/include -fdiagnostics-color=always
  • C++11(cc.cc11)
    /usr/bin/g++ -Wall -std=c++11 -o foo foo.cc -lm -I/include -fdiagnostics-color=always
  • C++11(O2)(cc.cc11o2)
    /usr/bin/g++ -Wall -std=c++11 -o foo foo.cc -lm -O2 -I/include -fdiagnostics-color=always
  • C++14(cc.cc14)
    /usr/bin/g++ -Wall -std=c++14 -o foo foo.cc -lm -I/include -fdiagnostics-color=always
  • C++14(O2)(cc.cc14o2)
    /usr/bin/g++ -Wall -std=c++14 -o foo foo.cc -lm -O2 -I/include -fdiagnostics-color=always
  • C++17(cc.cc17)
    /usr/bin/g++ -Wall -std=c++17 -o foo foo.cc -lm -I/include -fdiagnostics-color=always
  • C++17(O2)(cc.cc17o2)
    /usr/bin/g++ -Wall -std=c++17 -o foo foo.cc -lm -O2 -I/include -fdiagnostics-color=always
  • C++20(cc.cc20)
    /usr/bin/g++ -Wall -std=c++20 -o foo foo.cc -lm -I/include -fdiagnostics-color=always
  • C++20(O2)(cc.cc20o2)
    /usr/bin/g++ -Wall -std=c++20 -o foo foo.cc -lm -O2 -I/include -fdiagnostics-color=always
  • Pascal(pas)
    /usr/bin/fpc -O2 -o/w/foo foo.pas
  • Java(java)
    /usr/bin/bash -c "javac -d /w -encoding utf8 ./Main.java && jar cvf Main.jar *.class >/dev/null"
  • Kotlin(kt)
    echo "Invalid language selection"
  • Kotlin/JVM(kt.jvm)
    kotlinc -include-runtime -d foo.jar foo.kt
  • Python(py)
    /usr/bin/python -c "import py_compile; py_compile.compile('/w/foo.py', '/w/foo', doraise=True)"
  • Python 2(py.py2)
    /usr/bin/python -c "import py_compile; py_compile.compile('/w/foo.py', '/w/foo', doraise=True)"
  • Python 3(py.py3)
    /usr/bin/python3 -c "import py_compile; py_compile.compile('/w/foo.py', '/w/foo', doraise=True)"
  • PyPy3(py.pypy3)
    /bin/bash -c "/usr/bin/pypy3 -c \"import py_compile; py_compile.compile('/w/foo.py', '/w/foo', doraise=True)\" && mv foo.py foo"
  • PHP(php)
    /usr/bin/php foo.php
  • Rust(rs)
    /usr/bin/rustc -O -o /w/foo /w/foo.rs
  • Haskell(hs)
    /usr/bin/ghc -O -outputdir /tmp -o foo foo.hs
  • NodeJS(js)
    /usr/bin/node /w/foo.js
  • Golang(go)
    /usr/bin/go build -o foo foo.go
  • Ruby(rb)
    /usr/bin/ruby foo.rb
  • C#(cs)
    /usr/bin/mcs -optimize+ -out:/w/foo /w/foo.cs
  • R(r)
    /bin/sh -c "cat /dev/stdin >stdin && /usr/bin/Rscript --vanilla foo.r"

限制

咕噜OJ 评测机使用进程的CPU时间计算时间消耗,时间的限定为题目中评测点所指定的时间。

咕噜OJ 评测机使用进程虚拟内存与物理内存总和计算内存空间消耗。内存空间默认限定为256MiB,题目中特别指明的,限定为题目中评测点所指定的内存空间。

输入输出

若无特殊说明,咕噜OJ 使用标准输入输出(控制台输入输出,屏幕输入输出,STD I/O)。

评测状态

  • Waiting 评测:评测请求正在等待被评测机抓取
  • Fetched 评测:评测请求已被评测机抓取,正在准备开始评测
  • Compiling 评测:正在编译中
  • Judging 评测:编译成功,正在评测中
  • Accepted 通过:程序输出完全正确
  • Wrong Answer 不通过:程序输出与标准答案不一致(不包括行末空格以及文件末空行)
  • Time Limit Exceeded 不通过:程序运行时间超过了题目限制
  • Memory Limit Exceeded 不通过:程序运行内存空间超过了题目限制
  • Runtime Error 不通过:程序运行时错误(如数组越界、被零除、运算溢出、栈溢出、无效指针等)
  • Compile Error 不通过:编译失败
  • System Error 错误:系统错误(如果您遇到此问题,请及时在公告区进行反馈)
  • Canceled 其他:评测被取消
  • Unknown Error 其他:未知错误
  • Ignored 其他:被忽略
有“成绩取消”字样则说明管理员手动标记此记录为取消,可能违反了服务条款,比如代码被发现与其他用户的代码十分相似。

编译错误

可能有以下情况:

  • 1. 递交时选错了编程语言
  • 2. Java 的主类名没有使用 "Main"
  • 3. 对于 C/C++:见下
  • 4. 一般性的编译错误

对 C/C++ 选手的特别提醒:

  • 1. __int64 在 GNU C++ 中应写成 long long 类型
  • 2. main() 返回值必须定义为 int ,而不是 void
  • 3. for 语句中的指标变量 i 将会在如"for (int i = 0...) {...}"语句之后变为无效
  • 4. itoa 不是一个通用 ANSI 函数(标准 C/C++ 中无此函数)
  • 5. printf 中使用 %lf 格式是不正确的

训练

我们精心挑选了一些题目组成了训练计划。单击导航栏的“训练”即可进入!

比赛

按照赛制不同,有不同的递交、排名规则。

OI 赛制所有题目均以最后一次递交为准,特别地,请避免编译错误。

OI 赛制排名规则为:总分高的排在前面,总分相等则排名相同。

ACM/ICPC 赛制所有题目递交后立即评测,以是否通过为准。

ACM/ICPC 赛制排名规则为:通过题目数多的排在前面,通过题目数相同的做题耗时(含罚时)少的排在前。

乐多 赛制下,选手可以多次提交一道题目,并获得实时评测结果。

乐多 赛制下,多次提交会导致选手的得分被扣除,排行榜将显示用户的最高得分。

乐多 赛制下,每道题的最终得分为: $s \times \max(0.95^{n}, 0.7)$ 。$s,n$ 分别代表本次得分和本次提交前的尝试次数。

乐多 排名规则为:按照如上规则折算后的分数从高到低排名。

IOI(严格) 赛制下,不同于IOI赛制,排行榜将被关闭至比赛结束。

IOI(严格) 赛制下,每道题的排行榜得分将为用户每个子任务在所有提交中的最大得分的和。

时间与空间限制以题目说明为准,默认限制参见限制

通过率

通过率的影响极其恶劣,咕噜OJ 不提供也不承认通过率。

RP 算法

RP 可由题目,活动,比赛等获得。

难度算法

咕噜OJ 中题目的难度,根据递交数、通过率以及每个递交的递交时间和评测结果,通过算法计算得出。

因此,请注意以下几点:

  • 0. 一般地,难度的数值越大,该题目越难。
  • 1. 新题目的难度可能不准确;在题目获得大量递交之后,难度才会变得较为准确。
  • 2. 越早递交评测的用户代码的评测结果对题目难度影响越大。
  • 3. 题目的难度由算法计算得出,有可能出现不准确的结果。

测试数据集格式

详见配置文档

忘记密码和/或用户名

如果您无法登录,请仔细想想,是不是用户名记错了。比如,自己原本想要注册的用户名已经被注册,所以使用了一个带有前和/或后缀的用户名。

如果您确信您的账号被盗或者忘记了账号和/或密码,请及时重置密码或找回用户名

Markdown

Hydro 的 Markdown 区域使用 CommonMark 语法,并扩展了以下功能:

  • 基于 Katex 语法的数学公式支持。
  • 使用 @[](/user/uid) 提及用户。
  • 使用 ==text== 高亮文本。
  • 使用 ![alt](url =100x100) 设置嵌入图片的大小。
  • 使用 @[video](https://.../a.mp4) 嵌入视频文件。
  • 使用 @[bilibili](BVxxx) 嵌入站外视频。
  • 使用 @[pdf](https://.../a.pdf) 嵌入 PDF 文件。
  • 在题目/比赛/作业/训练中,可使用 file://文件名 的链接格式引用对应的附件。(推荐)
  • 支持使用一部分 HTML 标签。