程式解題系統使用手冊
* Online Judge 的運作原理
 

裁判系統會以數量不一的測試資料去測試您所送出的程式碼來判定您的程式是否完全正確,若通過所有的測試資料的測驗,則系統認定您的程式碼為通過,否則將會呈現不同原因的結果,如 NA, WA, TLE, MLE, OLE, CE, RE...等。因此必須在程式中放入一個 while 迴圈來讀取所有的測試資料。程式碼請參考 a001。

系統特色:
  • 可以告訴使用者錯誤答案發生在第幾行,方便除錯。
  • 使用者參與管理工作,使用者可利用系統出題目以及舉辦考試。
  • 可直接分享程式碼,以及站內簡訊進行討論。
  • 可預約競賽,時間一到即可自動開始,並自動結束,不需管理者操作。
  • 可在系統上進行開課,可成為一個開課平臺。
* 主要對象
  主要對象為程式語言初學者
* 錯誤訊息的意義
 

AC: Accept 即表示通過
NA: Not Accept 表示在多個測資點的情況下,有部分測資點無法通過
WA: Wrong Answer 表示答案錯誤, 請仔細比對,務必符合題目要求
TLE: Time Limit Exceed 表示執行超過時間限制
MLE: Memory Limit Exceed 表示程序超過記憶體限制
OLE: Output Limit Exceed 表示程序輸出超過限制
RE: Runtime Error 表示執行時錯誤,通常為記憶體配置錯誤 如:使用了超過陣列大小的位置
RF: Restricted Function 表示使用了被禁止使用的函式,並在錯誤訊息中指明使用了什麼不合法的函式。
CE: Compile Error 表示編譯錯誤
SE: System Error 包含 Compile, Runtime 等未定義的錯誤均屬於 System Error

由於本系統以初學者為導向,因此錯誤訊息儘可能提供最詳細的錯誤資訊,如 WA 訊息會告知您正確答案(題目測資已公開時),以及在第幾組資料時發生,讓使用者比較容易判斷錯誤發生在哪哩,而不會像在 ACM/UVa 裡明明做對了,但是就是有莫名的格式錯誤,卻找不出格式錯誤在哪的困境。

* 題目的進場/退場機制
 

本系統的特色之一是持 Open Source/WIKI 的概念,由廣大使用者共同參與共同成長的理念開放解題 30% 以上的使用者可以自行新增題目。這是 Online Judge 系統的創舉。但為了避免有問題的題目充斥,因此特別訂定“題目退場機制”。
凡符合以下事項 1 項含以上者,"站務管理員"保留將題目下架之權利。
* 題目內容易引發爭執者,如:宗教、政治議題、種族議題、歷史情結、文化衝突...等。
* 容易引發閱讀者不快者,如犯罪、色情、賭博、人身攻擊、影射...等不當文字。
* 題目敘述有誤或不完整、測資有誤,致使使用者無法作答者
* 進行廣告或置入性行銷者
* 與其它題目高度雷同或完全相同者
* 涉及著作人格權問題者,包含冒名投題、原作者提出異議並主張下架者...等
* 內含其它不當內容且遭致使用者投訴者

本辦法未盡周全之處,得經站務會議決議後修訂。

本辦法訂定時間 2009-05-08
(2009-07-06 第一次修訂)

*

使用者言論管理辦法

 

使用者違反下列規定時,站務管理員可依情況輕重限制使用者之使用權限,處理原則如下:

違規定義及標準:

以下所稱“言論”包含匿稱、帳號、討論區文章、題目內容、簡訊...等任何在 ZeroJudge 內發布的文字或圖片等相關資訊

一、不當言論
1、違反中華民國現行法律法規
2、涉及宗教、政治議題、種族議題、歷史情結、文化衝突...等
3、涉及犯罪、色情、賭博、人身攻擊、影射、隱私...等不當文字
4、在討論版要求貼出完整程式碼或是測資的正確輸出者。

二、網路濫用、攻擊
以任何形式的網路技巧濫用或攻擊,使得使用者無法順利使用網站功能。

三、廣告
請勿在言論當中進行商業廣告或置入性行銷

本辦法未盡周全之處,得經站務會議決議後修訂。

本辦法訂定時間 2009-07-06

* 各項解題語言所使用的系統編譯器
 

目前連結的評分主機為:ZeroJudgeServer

評分主機資訊:

本系統目前支援的程式語言如下:

C: gcc -std=c11 (gcc 7.4.0)
C解題範例


CPP: g++ -std=c++14 (g++ 7.4.0)
CPP解題範例


PYTHON: Python 3.6.9
PYTHON解題範例


PYPY: Pypy 7.3.7 (Python 3.7.12) (送出解答加速用)
PYPY解題範例


14253 alvin70812@g...(cyano) a101. P_5_4 反序數量 (APCS201806) -- Prof.Wu AC (42ms, 4.1MB)
2025-01-16 19:46
14252 alvin70812@g...(cyano) a099. P_5_2 最大連續子陣列(分治)(同P-4-13) -- Prof.Wu AC (17ms, 1.1MB)
2025-01-16 19:36
14251 t945935@gmai...(jack wu) a001. 哈囉 -- Brian Kernighan AC (60ms, 24.6MB)
2025-01-15 14:59
14250 t945935@gmai...(jack wu) a001. 哈囉 -- Brian Kernighan NA (score:20%)
2025-01-15 14:57
14249 11230022@st....(二誠42陳逸安) a113. P_6_15 一覽衆山小 -- Prof.Wu AC (40ms, 3.6MB)
2025-01-15 12:59
14248 11230022@st....(二誠42陳逸安) a113. P_6_15 一覽衆山小 -- Prof.Wu NA (score:60%)
2025-01-13 13:21
14247 11230022@st....(二誠42陳逸安) a112. P_6_13 周伯通的基地台 (@@) -- Prof.Wu AC (26ms, 3.4MB)
2025-01-12 16:46
14246 11230022@st....(二誠42陳逸安) a111. P_6_11 Catalan number -- Prof.Wu AC (5ms, 332KB)
2025-01-12 14:30
14245 zero(管理員) a097. P_4_15 最靠近的一對(closest pair) (@@) -- Prof.Wu AC (0.5s, 17.6MB)
2025-01-11 23:24
14244 zero(管理員) a209. Q_5_5 Closest pair(同 P-4-15, 分治版) (@@) -- Prof.Wu NA (score:85%)
2025-01-11 23:23
14243 zero(管理員) a209. Q_5_5 Closest pair(同 P-4-15, 分治版) (@@) -- Prof.Wu NA (score:28%)
2025-01-11 23:21
14242 zero(管理員) a209. Q_5_5 Closest pair(同 P-4-15, 分治版) (@@) -- Prof.Wu NA (score:85%)
2025-01-11 23:14
14241 ktlai(測試員) a209. Q_5_5 Closest pair(同 P-4-15, 分治版) (@@) -- Prof.Wu NA (score:85%)
2025-01-11 23:10
14240 ktlai(測試員) a097. P_4_15 最靠近的一對(closest pair) (@@) -- Prof.Wu AC (1.5s, 26.9MB)
2025-01-11 22:57
14239 s110565@stud...(江穎昶) a101. P_5_4 反序數量 (APCS201806) -- Prof.Wu AC (1.1s, 17.3MB)
2025-01-10 11:07
14237 chiangheting...(江赫霆) a224. Q_8_9 服務中心選位置 -- Prof.Wu NA (score:0%)
2025-01-04 17:43
14236 chiangheting...(江赫霆) a224. Q_8_9 服務中心選位置 -- Prof.Wu NA (score:0%)
2025-01-04 17:42
14235 chiangheting...(江赫霆) a224. Q_8_9 服務中心選位置 -- Prof.Wu NA (score:0%)
2025-01-04 17:41
14234 chiangheting...(江赫霆) a123. P_7_6 DAG的最長與最短路徑 -- Prof.Wu AC (0.7s, 18.4MB)
2025-01-04 17:26
14230 d11131520@ga...(m3vu/) a224. Q_8_9 服務中心選位置 -- Prof.Wu AC (0.1s, 9.7MB)
2025-01-03 20:39
Version:
ZeroJudge: 3.5.1
JudgeServer: 3.5 |
* 後記:關於 ZeroJudge
 

ZeroJudge 是一個 Online Judge 系統亦即線上解題系統,中文來說有許許多多不同的翻譯名詞,諸如:在線裁決系統、在線評判系統、在線提交系統...等等不一而足,建議還是直接稱呼 Online Judge 系統。主要是用來讓有意練習程式語言的人士(主要是學生),有一些題目可以練習,並且可以知道自己所寫的程式是不是正確。

目前世界上最著名的 Online Judge 便是大名鼎鼎的 UVa Online Judge System,沒聽過?那是因為大家都叫他 ACM。至於其中原因請參考 DJWS 所寫的『Online Judge System 起源與由來』。目前由西班牙 Valladolid (巴亞多利)大學(http://online-judge.uva.es/problemset/)所維護,目前已經有2000個題目,讓全世界的程式愛好者們想辦法去解決,這是全世界對寫程式有興趣的人一個練習的好地方。

然而,UVa(ACM)題目大多數都是需要用到許多演算法及程式技巧,對於中上程度的程式學習者具有很好的練習效果,但對於初學者,可就會覺得障礙連連,深受打擊了。

作者(Jiangsir)所服務學校(國立高雄師大附中)練習程式設計的學生也遭遇類似的情況,因此曾積極尋找備有初級題目的 Online Judge 系統(首先排除國外網站,因為語言障礙足以擊退絕大多數初學者),可惜無法如願,並且發現此時(2006)國內各大學尚未具備公開上線,可供自由練習的 Online Judge 系統。也曾嘗試考慮北京大學開發的(Peking JudgeOnline),但該系統並未開放原始碼許多功能無法動手修改。最後終於決定自行開發,於是 ZeroJudge 計畫誕生,代表從零開始。

大事紀:

  • 94學年度首度運用在學生課堂程式考試上,該版本為手動驗證,由人工判斷程式是否正確,此時僅為一個線上測驗系統。
  • 2006年中,改寫整個操作模式,使其朝向 Online Judge 架構發展,仍應用於程式考試上。
  • 同年,完成自動裁判服務 (Judge Server),可判斷出 Accept, Wrong Answer, Time Limit Exceed, Runtime Error, Restricted Functions, Compile Error, System Error...等狀態,至此可算是一個初步堪用的 Online Judge 系統。
  • 2007年初,公開上線供公眾練習使用,同時借此檢驗系統穩定度,並逐步發掘問題,逐步修正。
  • 2007年中,發展完成多重判決(分段計分)及條件式判決(Special Judge),因此可以正確判定可列舉的多重解答以及難以列舉或甚至無法列舉,但有規則可循的不特定測資。
  • 2007年底,獲教育部全國校園軟體創意競賽 教學應用及自由創意組 第二名。
  • 2008年初,實作完成多人管理模式,使用者可增加題目及舉辦考試,正式具備使用者參與的特性。
  • 2008年底,舉辦第一屆海峽兩岸青少年程式設計競賽。
  • 2009年,獲得教育部『國際大專院校程式設計推廣與培訓計劃』採用作為解題平臺,網址: http://ptc.moe.edu.tw/
  • 2010年,獲『高雄市資訊學科能力競賽複賽』採用作為正式競賽系統。
  • 2011年,提交之程式碼突破 100 萬筆。題目數量突破 1000 題。
  • 2014年,提交之程式碼達到 200 萬筆。
  • 2016年,提交之程式碼達到 300 萬筆。
  • 2017年,ZeroJudge 虛擬機版本開始提供下載測試。
  • 2020年,APCS 程式練習網上線 https://apcsclass.csie.ntnu.edu.tw