-
Notifications
You must be signed in to change notification settings - Fork 31
Expand file tree
/
Copy pathindex.html
More file actions
360 lines (360 loc) · 14.8 KB
/
index.html
File metadata and controls
360 lines (360 loc) · 14.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
<head>
<meta charset="UTF-8" />
<meta name="referrer" content="no-referrer" />
<title>AtCoder 中文站</title>
<link rel="stylesheet" href="src/style.css" />
<link rel="shortcut icon" href="images/favicon.ico" />
<script type="text/javascript" src="src/func.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/9000.0.1/themes/prism.min.css"
integrity="sha512-/mZ1FHPkg6EKcxo0fKXF51ak6Cr2ocgDi5ytaTBjsQZIH/RNs6GF6+oId/vPe3eJB836T36nXwVh/WBl/cWT4w=="
crossorigin="anonymous" referrerpolicy="no-referrer" />
<link rel="stylesheet"
href="https://cdnjs.cloudflare.com/ajax/libs/prism/9000.0.1/plugins/line-numbers/prism-line-numbers.min.css"
integrity="sha512-3/cdM9qaJ5lBlzRKqwhMw+ZcNCVonz66BO6HgJudG/P1azm9wFrru31SsBa4T4Ew1AOH8HfDXSWS6emWwPl42A=="
crossorigin="anonymous" referrerpolicy="no-referrer" />
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.16.3/katex.min.css"
integrity="sha512-6VMVcy7XQNyarhVuiL50FzpgCFKsyTd6YO93aaQEyET+BNaWvj0IgKR86Bf6+AmWczxAcSnL+JGjo+iStgO1gQ=="
crossorigin="anonymous" referrerpolicy="no-referrer" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.4/jquery.min.js"
integrity="sha512-pumBsjNRGGqkPzKHndZMaAG+bir374sORyzM3uulLV14lN5LyykqNk8eEeUlUkB3U0M4FApyaHraT65ihJhDpQ=="
crossorigin="anonymous" referrerpolicy="no-referrer"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/fomantic-ui/2.9.2/semantic.min.js"
integrity="sha512-5cguXwRllb+6bcc2pogwIeQmQPXEzn2ddsqAexIBhh7FO1z5Hkek1J9mrK2+rmZCTU6b6pERxI7acnp1MpAg4Q=="
crossorigin="anonymous" referrerpolicy="no-referrer"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/fomantic-ui/2.9.2/semantic.min.css"
integrity="sha512-n//BDM4vMPvyca4bJjZPDh7hlqsQ7hqbP9RH18GF2hTXBY5amBwM2501M0GPiwCU/v9Tor2m13GOTFjk00tkQA=="
crossorigin="anonymous" referrerpolicy="no-referrer" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/highcharts/10.2.1/highcharts.min.js"
integrity="sha512-AuSt9Vn4P8B4rNTBOOJGGqI89ktzlGugnty4mZa+dR7koM6sJCJVFwtRiM6lIVmFwHOGIdSCyY1l6UcD78CaBA=="
crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/highcharts/10.2.1/modules/exporting.min.js"
integrity="sha512-r0RhVDm8cW1TRmbiQN1wnfXBRxUkoao6eMPEDs+HpL5QyDdmwKKFTfztgOdtgzDqkYC60C116MWKtkT76F0IAg=="
crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/highcharts/10.2.1/modules/export-data.min.js"
integrity="sha512-empeVXImIgoDsUiZt8rvDYuIULbNE1s1c51wKGBo0fRn6LU8XT3rA/48WPWfnG1CaonZyIEk4P8qDIdtBOmVHA=="
crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/highcharts/10.2.1/modules/accessibility.min.js"
integrity="sha512-3v4MQPK+fT3z2i57H073Q3Emgd0TCeq+rvAFeDCd9vZ4VnYmtGU25LI5cni1ryxfHA8KDPg5MMTIqQLfabQlhA=="
crossorigin="anonymous"></script>
<script src="src/swld.js"></script>
</head>
<!-- Google tag (gtag.js) -->
<script async src="https://www.googletagmanager.com/gtag/js?id=G-PN5MKWERQW"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag() { dataLayer.push(arguments); }
gtag('js', new Date());
gtag('config', 'G-PN5MKWERQW');
</script>
<body>
<noscript> You need to enable JavaScript to view the page. </noscript>
<div class="ui main container">
<div id="page-top" class="display: inline;"></div>
<button class="circular ui icon button" onclick="_jumptotop()"
style="z-index: 999; position: fixed; right: 50; top: 50" id="button-top">
<i style="font-size: 1em" class="arrow up icon"> </i>
<p style="font-size: 10px; display: inline-block"> 到顶部</p>
</button>
<button class="circular ui icon button" onclick="_jumptobottom()"
style="z-index: 999; position: fixed; right: 50; bottom: 80" id="button-end">
<i style="font-size: 1em" class="arrow down icon"> </i>
<p style="font-size: 10px; display: inline-block"> 到底部</p>
</button>
<div class="ui large basic modal" id="show-prob-list"></div>
<h1 class="ui header" style="text-align: center">AtCoder 中文站</h1>
<div class="ui pointing menu">
<a class="item" onclick="switchTable('abc')"> ABC </a>
<a class="item" onclick="switchTable('arc')"> ARC </a>
<a class="item" onclick="switchTable('agc')"> AGC </a>
<a class="item" onclick="switchTable('abc_like')"> ABC-Like </a>
<a class="item" onclick="switchTable('arc_like')"> ARC-Like </a>
<a class="item" onclick="switchTable('agc_like')"> AGC-Like </a>
<a class="item" onclick="_switchList('ahc')"> AHC </a>
<a class="item" onclick="_switchList('others')"> 其他 </a>
<a class="item" onclick="labToggle('prob-archive')"> 筛选 </a>
<a class="item" onclick="labToggle('cont-page')"> 比赛 </a>
<div class="right menu">
<div class="item">
<div class="ui segment clrstyle">
<div class="ui transparent icon input">
<input type="text" id="user-name" placeholder="导入用户,多个用户用半角空格隔开" style="width: 260px" />
<i class="search link icon" onclick="importUser()"></i>
</div>
<div class="ui bottom attached indicating progress" id="sub-fetch-prog">
<div class="bar">
</div>
</div>
</div>
</div>
<div class="item" onclick="_clearStorage()" id="clear-storage">
<i class="broom icon">
</i>
</div>
</div>
</div>
<div id="cont-tbl" style="display: none">
<div id="cont-data">
</div>
<div style="text-align: center;">
<div class="ui indicating progress" data-percent="" id="progress-tre">
<div class="bar"></div>
<div class="label"></div>
</div>
<div class="ui indicating progress" data-percent="" id="progress-sol">
<div class="bar"></div>
<div class="label"></div>
</div>
<div class="ui indicating progress" data-percent="" id="progress-tag">
<div class="bar"></div>
<div class="label"></div>
</div>
<div class="ui indicating progress" data-percent="" id="progress-acc">
<div class="bar"></div>
<div class="label"></div>
</div>
</div>
</div>
<div id="prob-archive" style="display: none">
<div id="prob-list">
<figure class="highcharts-figure">
<div id="container" style="height:300px"></div>
<p class="highcharts-description"></p>
</figure>
<div class='ui form' style='margin: 1em 0'>
<div class='eight fields'>
</div>
</div>
<div class='ui form' style='margin: 1em 0'>
<div class='six fields'>
</div>
</div>
<div class="ui input">
<input id="diflb" style="width: 150;" placeholder="筛选难度下界" />
</div>
<div class="ui input">
<input id="difrb" style="width: 150;" placeholder="筛选难度上界" />
</div>
<div id="get-tag" class="ui selection multiple search dropdown">
<input type="hidden" name="intag" />
<div class="default text">
单击此处筛选题目标签
</div>
<div id="tag-list" class="menu">
</div>
</div>
<div class="ui checkbox">
<input id='tag-combined-or' type='checkbox' name='example'>
<label>
按或合并标签
</label>
</div>
<p></p>
<button class="ui violet basic button" onclick="setFilter()">
筛选
</button>
<button class="ui green basic button" onclick="clearFilter()">
重置
</button>
<button class="ui orange basic button" onclick="_getRandProblem()">
随机跳题
</button>
<p></p>
<table class='ui fixed celled table segment'>
<tbody>
<tr id='rndprob'>
</tr>
</tbody>
</table>
<div class='ui borderless menu' id='prob-list-menu'>
<a class="item">
<i class="ellipsis horizontal icon">
</i>
</a>
</div>
<table class='ui fixed sortable celled table segment'>
<thead>
<tr>
<th onclick="_setSortByTime()">编号</th>
<th onclick="_setSortByTitle()">标题</th>
<th>链接</th>
<th onclick="_setSortByDiff()">难度</th>
<th onclick="_setSortByTags()">标签</th>
</tr>
</thead>
<tbody id="archive-show">
</tbody>
</table>
</div>
</div>
<div id="cont-page" style="display: none">
<div class="ui secondary menu">
<a class="item" onclick="_showJoinPage()"> 参加 </a>
<a class="item" onclick="_showCreatePage()"> 创建 </a>
</div>
<div id="join-page">
<div class="ui fluid input">
<input id="rev-code" placeholder="输入邀请码" />
<button class="ui button" onclick="_redr()">
跳转到比赛界面
</button>
</div>
</div>
<div id="create-page">
<h4 class="ui header">设置比赛标题</h4>
<div class="ui fluid input">
<input id="get-title" placeholder="比赛标题" />
</div>
<h4 class="ui header">设置比赛类型</h4>
<div class="ui form">
<div class="three fields">
<div class="field">
<div class="ui radio checkbox" id="cont-type-prac">
<input type="radio" name="contest-type" />
<label>
练习赛
<i class="ui question circle icon helper" id="getPracticeContestInfo"></i>
</label>
</div>
</div>
<div class="field">
<div class="ui radio checkbox" id="cont-type-icpc">
<input type="radio" name="contest-type" />
<label>
ICPC 赛制
<i class="ui question circle icon helper" id="getICPCContestInfo"></i>
</label>
</div>
</div>
<div class="field">
<div class="ui radio checkbox" id="cont-type-atc">
<input type="radio" name="contest-type" />
<label>
AtCoder 赛制
<i class="ui question circle icon helper" id="getAtcoderContestInfo"></i>
</label>
</div>
</div>
</div>
</div>
<div class="ui popup top center transition hidden" id="practiceContestInfo"
style="width: 170px !important">
题目不加权,没有罚时
</div>
<div class="ui popup top center transition hidden" id="ICPCContestInfo" style="width: 210px !important">
题目不加权,罚时加和,每次不通过提交罚时为 5 分钟( CE 不计罚时)
</div>
<div class="ui popup top center transition hidden" id="atcoderContestInfo"
style="width: 250px !important">
题目可以设置为加权,罚时取各题通过时间最大值,每次不通过提交罚时额外加 5 分钟( CE 不计罚时)
</div>
<h4 class="ui header">设置开始时间</h4>
<p></p>
<div class="ui fluid input">
<input id="get-start-time" type="datetime-local" value="" + startTime + "">
</div>
<h4 class="ui header">设置结束时间</h4>
<p></p>
<div class="ui fluid input">
<input id="get-finish-time" type="datetime-local" value="" + finishTime + "">
</div>
<h4 class="ui header">
参赛选手
<i class="ui question circle icon helper" id="getAccountInfo"></i>
</h4>
<div class="ui popup top left transition hidden" id="accountInfo" style="width: 260px !important">
如果需要使用 CodeForces 账号,请使用
<code><AT账号>(<CF账号>)</code>
的格式,如:<code>houzhiyuan(houzhiyuan123)</code>
</div>
<div class="ui fluid input">
<input id="get-players" placeholder="以半角空格分隔" />
</div>
<h4 class="ui header">比赛题目</h4>
<div class="ui accordion" id="id-sample">
<div class="title">
<i class="dropdown icon"></i>
格式说明
</div>
<div class="content">
<p>
请填写题目链接内的 AtCoder
格式标识符(<code>atcoder.jp/<比赛标识符>/tasks/<题目标识符></code>),例如下:
</p>
<p>
<a href="https://atcoder.jp/contests/abc255/tasks/abc255_h">ABC255Ex</a>
的标识符为 <code>abc255_h</code>;
</p>
<p>
<a href="https://atcoder.jp/contests/abc111/tasks/arc103_b">ABC111D</a>
的标识符为 <code>arc103_b</code>;
</p>
<p>
<a href="https://atcoder.jp/contests/zone2021/tasks/zone2021_f">ZONE2021F</a>
的标识符为 <code>zone2021_f</code>;
</p>
<p>
<a
href="https://atcoder.jp/contests/code-festival-2017-qualc/tasks/code_festival_2017_qualc_f">CF17QualcF</a>
的标识符为 <code>code_festival_2017_qualc_f。</code>
</p>
<p>
同时支持 CodeForces 题目,格式为
<code>CFXXXI</code> ,如 CF1A。
</p>
<p>
在 AtCoder 赛制下可以为题目赋不同的权,格式为
<code><题目ID>(<分数>)</code> ,如
<code>abc277_h(600)</code> 。权默认为 1。
</p>
</div>
</div>
<p></p>
<div class="ui fluid input">
<input id="get-problems" placeholder="以半角空格分隔" />
</div>
<h4 class="ui header">生成邀请码</h4>
<div class="ui fluid input">
<input id="print-code" placeholder="邀请码" />
<button class="ui primary button" onclick="_printInviteCode()" id="getCode">
获取邀请码
</button>
</div>
</div>
</div>
</div>
<div class="ui vertical footer segment">
<div class="ui center aligned container">
<div class="ui section divider"></div>
<div class="ui buttons">
<button class="ui basic button" onclick="javascript:window.open('https://github.com/atcoder-for-chinese-developers/atcoder-for-chinese');">
<img src="images/logo1.png" class="ui centered mini image" />
</button>
<button class="ui basic button" onclick="javascript:window.open('https://atcoder.jp/');">
<img src="images/atcoder.png" class="ui centered mini image" />
</button>
<button class="ui basic button" onclick="javascript:window.open('https://kenkoooo.com/atcoder/#/table/');">
<img src="images/kenkoooo.png" class="ui centered mini image" />
</button>
<button class="ui basic button" onclick="javascript:window.open('https://semantic-ui.com/');">
<img src="images/semantic.png" class="ui centered mini image" />
</button>
<button class="ui basic button" onclick="javascript:window.open('https://greasyfork.org/zh-CN/scripts/452449-atcoder-%E4%B8%AD%E6%96%87%E5%8A%A9%E6%89%8B');">
<img src="images/greasyfork.png" class="ui centered mini image" />
</button>
</div>
<p style="text-align: center">
Powered by
<a href="https://github.com/atcoder-for-chinese-developers/atcoder-for-chinese">
AtCoder for Chinese Develop Team </a>.
<br />
Under
<a href="https://github.com/atcoder-for-chinese-developers/atcoder-for-chinese/blob/main/LICENSE">
the GPL-3.0 license </a>.
</p>
</div>
</div>
<div id="page-end" style="display: inline"></div>
<script>
_buildMainPage();
</script>
</body>