ソースコード
WITH ENT2 as (
select
  ENTRY_ID
  , USER_ID
  , STARTED_AT
from ENTRIES
where
  CONTEST_ID = 2
  and ENTRY_ID is not NULL
  and USER_ID is not NULL
), SUB2 as (
    select
      USER_ID
      , ENTRY_ID
      , PROBLEM_ID
      , SUBMIT_ID
      , SUBMITTED_AT
      , STATUS
      , POINT
    from SUBMISSIONS
    where CONTEST_ID = 2
      and ENTRY_ID is not NULL
      and USER_ID is not NULL
), J as (
select
 SUB2.USER_ID as UID
 , PROBLEM_ID
 , SUBMITTED_AT
 , STARTED_AT
 , cast(strftime('%s', SUBMITTED_AT) as integer) - cast(strftime('%s', STARTED_AT) as integer) as elapsed
 , STATUS
 , POINT
from SUB2 LEFT JOIN ENT2
  on SUB2.ENTRY_ID = ENT2.ENTRY_ID
 and SUB2.USER_ID and ENT2.USER_ID
order by SUB2.USER_ID, SUB2.ENTRY_ID, POINT
), ACT as (
    select
      UID,
      PROBLEM_ID,
      MIN(elapsed) as AC_TIME
    from J
    where STATUS = 'AC'
    group by UID, PROBLEM_ID
), S as (
select
  J.UID as USER_ID
  , SUM(POINT) as POINT
  , MAX(ACT.AC_TIME) as LAST_AC_TIME
  , SUM(STATUS <> 'AC' and elapsed < coalesce(ACT.AC_TIME, -999999)) as WRONG_ANS
from J INNER JOIN ACT
 on J.UID = ACT.UID and J.PROBLEM_ID = ACT.PROBLEM_ID
group by J.UID
order by POINT desc
)
select
  RANK() over (order by POINT desc, (LAST_AC_TIME + 300*WRONG_ANS) asc) as RANK
  , USER_ID
  , POINT
  , (LAST_AC_TIME + 300*WRONG_ANS) as EX_TIME
  , WRONG_ANS
from S
where POINT > 0 and LAST_AC_TIME is not NULL
order by RANK asc, USER_ID asc
提出情報
提出日時2022/10/20 08:44:36
コンテスト第3回 SQLコンテスト
問題順位計算
受験者keijak
状態 (詳細)WA
(Wrong Answer: 誤答)
メモリ使用量86 MB
メッセージ
テストケース(通過数/総数)
1/2
状態
メモリ使用量
データパターン1
AC
86 MB
データパターン2
WA
86 MB