모닥불에서

2024년 회고

올해는 블로그에 글을 많이 쓰지 못했습니다. 아쉬운 일입니다. 그만큼 바쁘게 살았다는 뜻도 될 것 같습니다. 여전히 저는 GPT를 사용하지 않고 수제 포스트를 작성하고 있으므로 많은 양해를 부탁드립니다…

여러 게임들에서 모닥불은 흥미로운 장치입니다. 모닥불 밖은 수많은 난관과 적들로 바글바글하지만, 모닥불에서만큼은 안심하고 쉬어갈 수 있고, 앞으로 어떻게 하면 좋을지 고민하면서 재정비할 수 있는, 하지만 언젠가 떠나야 한다는 것을 알고 있는, 그런 곳입니다.

이제 먹고 사는 문제를 생각해야 될 때가 되었습니다. 그 전에 고민하는 시간을 가져 보려고 합니다.

졸업

결국 졸업을 하네요. 사실 큰 감흥은 없는 것 같습니다. 대학 생활은 참 길었습니다. 2018년에 입학했으니 7년을 다녔던 셈이 됩니다. 학교에 들어오기 위해서 수험생활을 했던 글을 돌아보는데, 그때의 나와 지금의 나는 참 다른 생각을 하고 있구나 같은 생각이 들었습니다.

지금 와서 말하는 거긴 하지만, 사실 18수능 당시에 앞자리 수험생의 수학 30번 답안을 봤습니다. 보려고 해서 본 건 아니고, 문제를 풀다 앞을 봤는데 OMR에 마킹되어 있는 수가 또렷이 보였습니다.

’21’.

하지만 그걸 보고도 제가 마킹한 답은 ’42’였습니다. 그 수험생이 설마 정답을 냈을 거라고 생각하지 않았던 것도 있고, ‘베낀다’는 행위부터가 마음을 불편하게 하기에 충분했기 때문입니다. 만약 눈 딱 감고 베꼈으면 학교가 달라졌겠다 싶습니다 . 흔히들 서강대생들은 소위 ‘연고대’에 떨어져서 오기 때문에 특유의 내재된 자격지심이 있다고들 하는데, 입학 당시에 ‘그때 30번을 베꼈으면!’이라던가, ”간판’을 낮추고 다른 학교를 갈 걸!’ 같은 생각을 안 했다면 거짓말일 테니, 그렇게 틀린 말은 아닌 것 같습니다.

지금은 전혀 그렇게 생각하지 않습니다. 2018년의 ACM-ICPC Team이 없었으면 제가 문제해결을 이렇게까지 좋아하는 사람이 됐을 리가 없습니다. 그리고 그러다가 맡게 된 학회장이라는 역할은, 극히 내향적이고 남들 앞에 잘 나서지 못하던 제 성격을 180° 바꿔놓았습니다(그렇다고 아직 ‘외향적’이라고 할 수는 없을 것 같네요). 가장 중요하게는, 제가 서강대를 가지 않았다면 솔브드도 없었을 거라는 건 틀림없습니다. 물론 자료구조 성적을 별 시덥잖은 이유로 B+ 주는 등 마음에 안 드는 점들도 있기야 하지만 이곳에서의 학교생활은 지금의 저를 만든 중요한 조각이 되었습니다.

더구나 집안 형편이 어려운 와중에 4년간 학비를 전액 지원받아 다니면서 정말로 하고 싶은 일들에 열정을 쏟을 수 있었던 점은 정말로 학교에 감사한 점입니다. 다만 학교가 제게 해 준 것에 비해 제가 그렇게 학교를 열심히 다녔느냐 하면… 처음에는 공부를 좀 열심히 했던 것 같은데 나이를 먹을수록 그렇지 않게 된 것 같고, 수업 안 듣고 문제 풀거나 개발을 했습니다. 죄송합니다. 얼마나 학교의 위상을 올렸을지는 모르겠지만 대회 나가서 상 많이 타 왔으니 용서해주세요…

조교

올해는 CSE4152 문제해결프로그래밍 과목의 학부조교를 했습니다.

위에다 학교 찬양을 마구 해 뒀지만 사실 학교 들어와서는 커리큘럼에 사소한 불만들이 좀 있었습니다. 커리큘럼이 컴퓨터과학을 제대로 배우는 데는 문제가 없긴 했는데요, 몇몇 과목에 아쉬운 부분이 있었습니다. 예를 들어 컴퓨터공학설계및실험I에서는 PHP 프로그래밍과 MFC 어플리케이션 개발을 실습했는데, 회사를 다녀오니 많은 과목들이 최신화되어 있어서 놀랐습니다. 그리고 그 놀람 중 하나는 알고리즘 문제해결 과목의 신설이었습니다.

이주호 교수님의 의지로 신설된 PS 과목은 과제와 시험이 전부 문제해결입니다. 학생들이 엘리스에 코드를 제출하면 실시간 자동 채점을 받습니다. 저는 이번에 과제 데이터를 준비하고 시험 문제를 출제하는 조교 역할을 맡았습니다. 기술적으로는 엘리스 플랫폼 상에서 BOJ의 ‘스페셜 저지’와 ‘인터랙티브’에 해당하는 것들을 구현해야 했던 점이 제일 어려웠지만 제가 나름 재사용 가능하도록 만들어 놨으니 졸업하더라도 이후 조교분께서 아마 활용해서 문제를 만드실 수 있지 않을까 싶습니다. 별개로 엘리스는 문제 수정 시 모든 데이터를 다운받아서 브라우저 메모리에 저장하도록 되어 있어서 큰 데이터를 준비하기 부담스럽고, ‘부분문제’를 만들더라도 한 태스크에서 메모리 초과 시 전체가 0점이 되는 등의 불편함이 있습니다. 부디 외고쳐졌으면 좋겠습니다.

이외에는 문제해결 과목이 생겼다는 데에 큰 의미가 있다고 생각하고, 앞으로도 학생들이 알고리즘 문제해결에 재미를 붙일 수 있는 좋은 계기로 지속적으로 작용할 수 있으면 좋겠습니다. KAIST 등 다른 학교에 문제해결 수업이 있는 게 부러웠는데 이제 남부럽지 않은 학교가 되었네요.

중간고사/기말고사 문제들이 궁금하시다면 BOJ에서 풀어보실 수 있습니다.

솔브드

올해 초에 온사이트 프로그래밍 대회인 그랜드 아레나 파티를 개최할 수 있었습니다!

하지만 안타깝게도 이후에 아레나가 더 열리지는 않고 있습니다. 아레나는 레이팅을 매기는 대회이기 때문에 솔브드에서 모든 아레나를 검수해 왔는데, 검수를 수없이 해온 저로서도 아레나 일정에 맞춘 대회 검수는 제 생각보다 훨씬 많은 리소스를 필요로 했고, 급기야 몇몇 대회에서 실제로 문제가 발생하기도 했습니다. 그렇다고 검수를 다른 분께 맡기자면 검수비를 들여야 하는데, 아무리 봐도 수고에 비해 합당한 검수비를 드릴 수 없을 것 같아서, 이걸 해결할 방법을 찾지 못하는 한 당분간 열리지 않을 것 같습니다. 너무 아쉽습니다.

그런가 하면, 솔브드를 전세계 경쟁 프로그래밍 커뮤니티에 소개하는 영광스러운 일도 있었습니다. ICPC 아스타나 월드 파이널 일정 중 하나로 경쟁 프로그래밍 관련 여러 도구 및 방법론을 소개하는 CLI 심포지움이 있는데, 대회 측에서 솔브드를 소개해줬으면 좋겠다고 발표자로 초청해 주셔서 카자흐스탄에 다녀왔습니다. 발표는 영어로 30분간 진행했습니다.

하필이면 제가 마지막 순서고 제 앞에는 코드포스의 KAN님과 앳코더의 maroonrk님이 발표하셔서 정말로 많은 긴장을 했습니다. 청중께서는 주로 ICPC 리저널 콘테스트 디렉터(RCD) 혹은 월드 파이널 스탭이었는데, 다행히도 걱정했던 것과는 달리 반응이 꽤나 좋았다고 합니다. 인정받은 만큼 앞으로도 알고리즘 문제해결 커뮤니티에 의미 있는 기여를 할 수 있으면 좋겠습니다.

이외에 올해의 솔브드는 대부분 보이지 않는 곳에서 일했습니다. 가령, 관리 콘솔을 새로 만들었습니다. 관리 콘솔은 제가 주로 처리하는 민원(?)들을 좀 더 빠르고 편리하게 처리할 수 있게 해 줘서, 다른 일들에 집중할 수 있었습니다. 가령 프로필 뱃지를 등록하려면

일러스트레이터에서 작업 -> 포토샵에서 $512\times 512$로 리사이징 -> TinyPNG로 용량 최적화 -> S3에 게시 -> URL 나오면 그제서야 솔브드 DB에 등록

을 해야 했는데, 이제는 리사이징, 최적화, 업로드, DB 등록을 한 화면에서 다 해 줍니다.

그리고 사이트 도움말 페이지도 만들었습니다. 이건 좀 늦은 감이 있는 것 같지만 항상 better late than never입니다.

말고도, 신기능 랜덤 마라톤, 프로필 배경 상점, 그리고 문제 오류 제보가 업데이트되었습니다. 길라잡이도 작업에 착수해서 이제 글을 작성하고 있는 단계입니다.

솔브드는 2022년 12월에 회사로 바뀌어서 업력 2년을 맞았습니다. 솔브드의 비전은 그때도 지금도 이렇습니다.

  • BOJ에는 정말 많은 문제들이 아카이브되어 있습니다. 이를 잘 체계화해서 알고리즘 문제해결 학습자 및 향유자를 위한 최대의 아카이브 및 커뮤니티로 자리매김하고 싶습니다.
  • 알고리즘 문제해결은 사고력과 구현력을 키우는 데에 많은 도움을 주고, 무엇보다도 재밌습니다. 솔브드는 이 분야의 저변을 확대하고, 또한 대중화하고 싶습니다. 특히 코딩 테스트를 준비하던 학습자가 문제해결 자체에도 재미를 붙일 수 있게 하고 싶습니다.
  • 한국에는 많은 알고리즘 문제해결 동아리들이 있고, 많은 고등학교/대학교 대회, 심지어 개인 주최 대회까지 꾸준히 많이 열리고 있습니다. 이런 생태계가 최대한 지속 가능하도록 돕고 싶습니다.

이런 것들을 제대로 하기 위해서는 많은 시간이 필요합니다. 솔브드에 쏟을 시간을 확보하려면 다른 일에 쏟을 시간을 줄여야 합니다. 결국 솔브드가 재정적으로 자생 가능해야 한다는 뜻입니다.

2024년 말 기준으로 솔브드는 재정적으로 자생이 가능하기는 합니다만, 저는 재정적으로 자생이 안 됩니다. 뭔가 다른 일을 해서 먹고살아야 합니다. 엎친 데 덮친 격으로 올해 여름에 솔브드 굿즈 샵과 관련해서 결제대행사가 대금을 3개월 늦게 정산하게 된 큰 사고가 있었고, 결제대금을 정산받지 못했기에 굿즈를 (주문해주신 분들께 받은 돈이 아닌) 사비로 발주해야 했던 일이 있었습니다. 큰 규모의 유동성을 잃어서 하반기에는 정말 많이 고생했습니다.

솔브드의 사업화는 학교를 다니는 동안 ‘이걸 평생 할 수 있을까?’를 테스트하기 위한 일종의 실험이었습니다. 실험이 실패했다고 생각하지는 않으나 실험 여건과 기간은 꽤 부족했던 것 같습니다. 여전히 문제해결의 효용과 즐거움을 믿기 때문에 인생이 힘들어진다고 사이트를 닫을 일은 없지만, 제가 의미있다고 생각하는 일을 계속하기 위해서 인생을 갖다가 다이나믹 프로그래밍을 돌리면 이 방향이 제일 옳을 것 같다고 생각해서, 아래와 같이 결정했습니다.

재(?)입사

내년 1월 6일부로 넥슨코리아에서 일하는 것으로 되었습니다. 알고리즘 하고 싶다는 이야기를 하다가 갑자기 게임회사가 나오는 게 좀 의아할 수 있지만 나름의 이유가 있습니다.

첫째로, 제가 가게 될 부서는 오는 1월에 신설되는 다소 실험적인 조직 ‘알고리즘연구팀’입니다. 이곳에서는 사내 코드의 최적화 업무를 할 예정이지만, 주 업무는 놀랍게도 알고리즘 대회 준비입니다.

두 번째로, 저는 넥슨의 사회공헌 사업인 넥슨청소년프로그래밍챌린지(NYPC)의 방향이 제가 솔브드를 만들면서 생각했던 비전과 많은 부분 일치한다고 생각하여, 엔진스튜디오를 퇴사하고도 계속 NYPC 사외에서 문제를 출제하고 자문을 해 왔습니다.

코딩 교육으로 한정하지 않더라도 넥슨의 사회공언 사업에는 진정성이 있다고 생각합니다. 자원과 관심과 의지가 있는 환경에서 제가 의미있다고 생각하는 일을 하는 것만큼 보람찬 것은 없을 겁니다. 물론 이제 회사로서의 솔브드는 정리해야겠지만, 솔브드가 지금 하고 있는 일들도 충분히 의미가 있기 때문에 솔브드가 사라지는 일은 없겠습니다. 개인이 취미로 (하지만 진지하게) 운영하는 사이트였을 때로 돌아갈 뿐입니다.

대회

알고리즘 대회를 진지하게 준비하기 시작한 이후 만들었던 버킷 리스트가 있습니다. 여러 번 이야기했던 것 같은데, ICPC 월드 파이널 진출, 코드 잼 라운드 3 진출, 그리고 SCPC(삼성전자 대학생 프로그래밍 대회) 수상이었습니다. 그중 월드 파이널은 2021년에, 코드 잼 라운드 3은 2022년에 이뤘습니다.

버킷 리스트의 마지막에 있었던 SCPC가 가장 쉬워야 할 터인데, 4번이나 본선에 진출할 동안 여태 상을 못 타다가 마지막 기회인 올해 드디어 수상에 성공했습니다.

그런데 졸업학기라서 그런지 소프트웨어멤버십 가입은 안 시켜 주더라고요. 아쉽습니다.

올해에는 ICPC 슈퍼리저널이 신설되었습니다. 그래서 2023-2024 시즌의 첫 슈퍼리저널인 2월 하노이 대회에 참가할 수 있었습니다. 대략 16등까지가 월드 파이널에 진출하는데, 37위로 그렇게 좋은 성적은 아니었습니다. 어려운 평면 그래프 문제를 평면 그래프의 특성을 사용하는 부분 빼고 풀어냈는데, 제대로 하나 배워가는 계기가 되었습니다.

2024-2025 시즌 ICPC 리저널은 서울과 요코하마를 나갈 계획이었는데, 요코하마가 장소 문제로 저희를 등록거부하면서 아쉽게도 서울에만 나가게 되었습니다. 5년만의 수상을 하고 내년 2월 싱가포르에서 열리는 슈퍼리저널 대회로 진출하게 되었습니다. 학교 순위에서 1위를 못 한 건 처음인데, 아쉽기도 하지만 제가 너무 오래 해먹은 것도 맞기 때문에 이제 갈 때가 된 것 같습니다.

돌아보니 관광으로 방문한 지역보다 ICPC에 나가기 위해 방문한 지역이 더 많아진 것 같습니다. 태국, 러시아, 인도네시아, 카자흐스탄, 싱가포르가 있네요.

이외에 UCPC는 팀 ‘개척단 훈련소’로 나가서 4등을 하고 왔는데, B번을 고민하던 기억 말고는 없습니다. 즐겜모드로 나갔으나 저 외의 팀원들이 코드포스 최고 레이팅이 무려 2957과 3042였기 때문에…

취미

shiftpsh.com 사이트를 리뉴얼했습니다. 예전 버전은 shiftpsh.com/2021애서 보실 수 있습니다. 디자인을 훨씬 깔끔하게 만들면서도 더 많은 내용을 넣을 수 있도록 했습니다. 한별이 갤러리도 만들었어요!

2021년도 사이트까지는 제가 2017년에 만들어 뒀던 개인 AWS EC2에다가 FTP 접속해서 pull 받고 빌드 돌리고 그랬는데, 지금은 static generation을 하고 S3에서 호스팅합니다. 소스 코드가 GitHub에 올라와 있습니다. 내년에는 영어 지원을 해 보고 싶네요.

1월에는 작탁을 사서 친구들과 심심할 때마다 마작을 칠 수 있게 되었습니다. 그전에도 마작패는 있었는데, 자동으로 패를 섞는 것의 장점을 실감하게 될 뿐이었습니다.

작탁이 있으니 아카도라와 점봉 같은 걸 추가 구매해서 커스텀 룰도 할 수 있습니다. 가령 5삭/5통 전부 적도라에다가 시로폿치도 있는 3인 마작 같은 걸 할 수 있습니다.

올해로 오락실에 다닌 지 10년째가 됩니다. 10년 중 3년은 유비트를 열심히 했고, 3년은 사볼을 열심히 했고, 최근 4년은 마이마이를 하고 있습니다. DX+ 버전부터 열심히 하기 시작했던 셈이네요. 작년은 레이팅 15545로 마감했는데, 올해는 갑자기 16000을 달성했습니다.

또 예전에 유비트 성과 관리 앱 ‘유비트북’을 만들었던 경험을 살려 마이마이 성과 관리 사이트를 만들기도 했습니다. 제가 필요로 했던 기능들을 잔뜩 넣었더니 참 쓰기 좋은 사이트가 나왔습니다.

츄니즘도 무지개를 달성해서 쌍무지개가 되었습니다. 마이마이 쪽 무지개는 슈퍼 무지개인 것 같기는 한데요.

사볼에 대한 열정은 여전하지 않지만 애정은 여전합니다. 니아·노아 생일 카페의 디자인을 맡았습니다.

여행

2월에는 ICPC를 위해 베트남 하노이에 다녀왔습니다.

베트남이면 동남아시아 국가인데 북쪽이라 그런지 기온이 16도쯤을 유지하고 있어서 꽤나 쾌적했습니다. 롯데호텔에 묵었는데, 1층에 롯데리아와 롯데마크, 그리고 인생네컷이 있어서 잠실인가 싶었습니다.

하노이 탑은 못 봤지만 대신 탑 오브 하노이라는 바를 갔다 왔습니다.

하노이에서 돌아올 때 다낭에서 환승했는데, 마치 한국에 온 것 같았습니다. 세상에 어떤 국제공항이 한국으로 가는 비행기편만 필터해서 보여주는 곳이 있을까요? 정말 신기한 곳이었습니다.

5월에는 일본 후쿠오카에 다녀왔습니다. 순전히 온게키를 하러 가기 위한 여행이었습니다. 그래서 온게키는 재미있었느냐 하면 너무 재미가 있어서 20만원쯤 쓰고 왔던 것 같습니다…

리듬게임에 20만원을 쓸 수 있는 이유는 당연하게도 카드 가챠 시스템이 있어서입니다. 마이마이에 20만원 쓰려면 한 세월 걸리지만 온게키는 10분정도면 할 수 있습니다.

9월에는 ICPC 월드 파이널 발표자로 초청받아서 예정에 없던 카자흐스탄 여행을 떠났습니다. 보통 가는 알마티가 아니라 아스타나였는데, 건물이 큼직큼직한데도 광활해서 놀랐던 기억이 있습니다.

숙소와 비행기 값은 ICPC 재단에서 내 주셨습니다. 감사합니다.

‘ICPC Staff’가 새겨진 티셔츠도 받았습니다. 엄청난 레어템인데 한 번 세탁했더니 글자가 갈라져서 무서워서 못 입고 있습니다. 대신 참가자들에게는 티셔츠를 세 벌씩이나 주기 때문에 같이 간 카이스트 팀 티셔츠 뺏어서 입고 다닙니다.

여기에 마작 세트를 들고 갔더니 마작에 대한 깊은 이해가 있는 일본 참가자들과 국제교류를 이룰 수 있었습니다.

월드 파이널에서도 어김없이 그사건이 일어납니다.

타바스코보다 큰 한별이도 있습니다.

시국

시위도 나갔습니다. 아니 집 앞 바에서 할 거 하고 있는데 갑자기 지인이 와서 계엄령이 났다고 하길래 취한 줄 알았습니다. 지금도 황당합니다. 어쩌다 이런 말도 안 되는 일들이 일어난 걸까요…

탄핵 정국은 현재진행형입니다. 정치는 나의 삶과 지극히 관련이 있다는 걸 한 번 더 체감하게 되는 계기가 되고 있습니다. 대선이 머지않아 있을 것 같은 느낌인데, 이번 일은 잊지 않고 앞으로 계속해서 잘 뽑아야겠습니다.

모닥불을 나서며

올해도 참 힘든 해였습니다. 그렇지만 꽤 멋지고 보람있게 보낸 것 같습니다.

솔브드의 결제대행사 사고는 불가항력적이었고, 이로 인해서 올해 하기로 마음먹었던 것들을 다 하지 못했던 건 아쉬운 일입니다. 회사로 돌아가기로 결정한 건 이런 일의 결과 중 하나지만, 오히려 먹고살 걱정이 해소되면 하고 싶은 일들을 하는 데에 더 집중할 수 있지 않을까 하는 기대도 있습니다.

당장 다음 주부터 회사에 출근하기는 하지만 아직 정비해야 할 것들은 많이 남아 있습니다. 이사를 어디로 가야 할지, 솔브드를 어떻게 정리해야 할지 같은 자잘한 것들도 있지만, 무엇보다 재작년과 작년을 정말 힘들게 보냈는데 잠시 휴식이 필요하겠습니다. 이번 연말은 별 하는 일 없이 요란하지 않게 보내고 있습니다. 새해에도 그렇게 좀 쉬다가, 1월 여행을 다녀오고 나서 본격적으로 모닥불을 나서서 현생을 견디러 나가고자 합니다.

회사를 가게 된다면 프론트엔드 엔지니어를 하러 가게 될 줄 알았는데 그렇지 않게 되었습니다. 하긴 ICPC 월드 파이널에서 발표를 할 줄 알았느냐고 한다면 그것도 모르는 일이었을 터입니다. 삶은 정말 모르는 일의 연속이다 싶습니다. 내년에는 어떤 일들이 저를 기다리고 있을지 기대가 됩니다.

올 한 해도 감사했습니다. 새해 복 많이 받으세요!

목적지는 레이팅이 아니다

이게 무슨 해괴망측한 소리일까요?

이 글은 알고리즘 문제해결 트레이닝에 대한 사견私見입니다.


지금부터 전제를 하나 합시다.

  • 밥 먹고 알고리즘 공부만 하면 얼마나 걸릴지는 몰라도 언젠가는 코드포스 레이팅 3,000이 될 겁니다.

뭐, 세상에는 레이팅이 3,000을 넘는 괴물들도 다수 있지만 일단은 이론적으로 밥만 먹고 문제만 풀면 언젠가는 3,000에 갈 수 있다고 합시다. 사람마다 걸리는 시간은 다르겠지만요. 이를 근거로 공부한 시간 $t$에 대한 실력 $f$를 아래와 같이 모델링해 봅시다.

\[f\left(t\right) = 3\ 000 \left(1-a^t\right)\]

공부한 시간 v. 레이팅

하지만 실력은 올라가기만 하는 건 아닙니다. 어떤 날은 컨디션이 좋아서 머리가 잘 돌아가고 문제가 잘 풀릴 수도 있는 반면 어떤 날은 피곤하거나 우울하거나 뭐 물리적으로는 손가락이 아프다거나 할 수 있죠. 그렇기 때문에 조금 더 정확하게 실력을 모델링하려면 노이즈를 끼워야 할 겁니다. 대충 아래와 같은 모델은 어떤가요?

\[f\left(t\right) = 3\ 000 \left(1-a^t\right) + b \sin \left(ct\right)\]

공부한 시간 v. 레이팅 (약간 더 현실적인 모델)

좋습니다. $t$의 스케일이 얼마일지는 모르겠지만 이게 우리의 현재와 미래 실력을 대략적으로 모델링해준다고 합시다. 믿어 주세요.

하지만 제 레이팅은 계속 제자리인걸요

위 그래프에서 어떤 사람이 레이팅 1,400에서 1,600까지 가는 여정만을 한 번 살펴봅시다.

1,400 — 1,600

아마 가장 먼저 드는 생각은 이거일 거예요. ‘실력은커녕 내 그래프는 이거랑 비슷하지도 않은데…’ 맞아요. 쉽게 와닿지 않죠? 하지만 제가 여기에다 점을 몇 개 찍어볼게요.

1,400 — 1,600

… 어떤가요, 있을 법한 그래프이지 않나요? 운이 정말 나쁘다면 이런 경우도 가능할 거구요.

4연속 하락

이 그래프의 주인공은 과연 영영 파란색 닉네임을 달지 못하게 되는 걸까요? 우리는 결국에는 1,600이 될 거라는 사실을 알고 있지만, 점선을 지우고 나서 이게 자신의 그래프라고 생각한다면 정말 슬플지도 모르겠네요…

사실 저도 경험해 봤습니다

대회는 실력의 샘플링에 불과하다

여기서 중요한 관찰이 하나 있습니다.

우리가 모델링한 실력 그래프와 코드포스 레이팅 그래프 사이에는 큰 차이점이 있습니다. 우리 그래프는 연속적이지만 코드포스 그래프는 그렇지 않다는 점입니다. 이는 ‘대회’라는 시스템의 본질에서 기인합니다.


대회는 우리 실력이 지금 이 순간 어땠는지만을 알려주지, 실력을 실시간으로 알려주지는 않습니다.


이게 왜 큰 차이냐면, 코드포스 레이팅 그래프가 우리의 실력을 정확하게 말해주지 않는다는 뜻이기 때문입니다.

한 마디로, 대회는 실력의 샘플링에 불과합니다. 심지어 샘플링 주기가 짧지도 않습니다. 그래서 사실 그래프에 찍힌 점들만 보고 거시적으로 어디로 갈지 예측하는 건 불가능에 가깝습니다. 위에서는 실력 기복을 $b \sin ct$라고 퉁쳤지만 사실 그렇지도 않을 거구요.

게다가 보통 한 대회에는 문제가 6개밖에 없기 때문에, 모든 분야가 고르게 출제될 수도 없으며, 운 나쁘게 내가 자신없는 분야가 출제되어서 평소보다 못 풀 수도 있습니다. 다시 말하면 샘플링 자체도 그렇게 완벽하지는 않습니다.

문제 수 이야기가 나와서 말인데 레이팅 말고 대회에서 해결한 문제 수로 바꿔서 생각해 볼까요? 코드포스에서는 몇 문제를 풀었는지가 레이팅을 결정하는 중요 요소로 작용하죠. 하지만 푼 문제 수는 보통 한 자리 정수입니다. 굉장히 이산적인데요, 대회마다 나오는 문제의 난이도가 일정하다고 하면, 위에서 만든 실력 모델링 그래프는 대략 아래처럼 됩니다.

문제 수로 봤을 때의 그래프

똑같은 3솔브여도, C를 간신히 해결한 3솔브와 D를 다 생각했는데 시간이 약간 부족해서 못 푼 3솔브는 다를 겁니다. 여유롭게 3솔브를 하고 아깝게 4번째 문제를 못 풀었다면 적어도 간신히 3솔브를 했을 때보다는 확실히 성장했을 테지만, 결과적으로 스코어보드에 보이는 건 똑같이 세 개의 초록색이겠죠.

마지막으로, 코드포스의 레이팅 공식조차 실력을 완벽하게 표현해 주지는 못합니다. 코드포스의 공식은 마지막으로 친 대회 결과에 상당히 큰 영향을 받도록 설계되어 있습니다. 최근 5개 정도 대회만 실력을 유의미하게 반영해 주는데요, 연속적으로 운이 좋거나 나쁘면 아예 색깔이 바뀔 수도 있는 시스템이라 평소 실력을 제대로 반영해 주지 못합니다. 관련해서는 djm03178님의 Codeforces 레이팅에 관련된 글을 읽어 보면 좋습니다.

그러니까 문제를 평소보다 못 풀어도 괜찮고, 레이팅이 떨어지더라도 괜찮아요. 애초에 그게 진짜 본인의 실력은 아닐 거예요.

그래서 목적지는 레이팅이 아니다

라고 말하고 싶습니다. 바꿔 말하자면, 레이팅은 진짜 실력이 아니고, PS 실력을 키우는 것과 레이팅을 올리는 것은 비슷해 보이면서도 다르다고 생각합니다.

물론 색깔을 바꾸기 위해 알고리즘 문제해결 공부를 하는 것도 정말 멋진 일입니다. 하지만 그 과정이 정말 지치고 힘이 든다면, 레이팅은 좋은 목표가 아닐지도 모릅니다.

하지만 실력을 키우면 레이팅은 자연스럽게 올라갈 거예요. 이런 마음가짐을 가지고, 대회를 충분히 많이 치면 언젠가는 목표하는 레이팅이 될 수 있다는 희망을 갖고, 나 자신의 가능성을 믿도록 합시다.

조금 현실적인 조언

  • 업솔빙 / 문제 수를 목표로 하기 — 그래도 해결하는 문제 수는 레이팅보다 직관적이면서도 그렇게 많이 변하는 값은 아니기 때문에 목표로서 유의미하다고 생각합니다.
    문제 레이팅을 목표로 하는 것과 맥락을 같이하는데요, 대회에서 풀었던 제일 어려운 문제의 다음 번 문제를 해결하려고 시도해 봅시다. 모르겠다면 에디토리얼을 보고 인사이트를 얻어갑시다. 아까운 실수로 틀렸다면 너무 자책하지 말고 오히려 자신을 격려해 줍시다. 뼈아픈 실수일수록 반복하는 일이 적을 거예요. 궁극적으로는 대회에서 해결할 수 있는 문제 수를 늘리는 것을 목표로 합시다.
  • 문제 레이팅을 목표로 하기 — 문제 수를 목표로 하는 것과 맥락을 같이합니다.
    코드포스 대회가 끝나면 Problemset에 문제 레이팅이 공개됩니다. 목표 문제 레이팅 $r$을 정해 두고, 대회가 끝난 후 $r$ 이하의 문제들을 풀어보는 것으로 단련해 봅시다. 궁극적으로는 대회 시간 내에 $r$ 이하의 문제들을 안정적으로 풀 수 있는 것을 목표로 합시다.
  • 버추얼 컨테스트 돌리기 — 코드포스에는 끝난 대회를 가상 참가할 수 있는 기능이 있습니다. 또 가상 컨테스트 참여로 가상 레이팅을 계산할 수 있는 서비스도 있습니다. 이 서비스를 활용해 가상 컨테스트를 자주 치면 실력도 단련할 수 있고, 앞서 언급한 샘플링 주기의 문제도 어느 정도 해결할 수 있겠죠.
  • Atcoder — 일본 기반의 알고리즘 대회 사이트입니다. Atcoder는 코드포스의 레이팅 공식과 달리 현재까지 참여한 모든 대회의 퍼포먼스를 가중평균하는 식으로 레이팅을 계산하기 때문에 참가자의 평소 실력을 좀 더 잘 반영한다고 생각합니다. 게다가 문제도 코드포스보다 훨씬 깔끔하며, 시스텟이 없고, 무엇보다 시간대가 같아서 주말 오후 9시에 부담없이 참여할 수 있다는 장점도 있습니다. 강력하게 추천합니다.
  • 팀 연습 하다 오기 — 조금 더 긴 시간 동안 더 어려운 문제들에 대해서 생각해볼 수 있는 좋은 방법입니다. 새로운 인사이트를 얻을 수 있습니다.
  • 당분간 쉬기 — 너무 지쳤다면 괜찮아질 때까지 쉬어도 괜찮습니다. 알고리즘은 잊고 놀러 나가서 맛있는 거 먹고 옵시다. 금방 다시 회복할 수 있을 거예요.

알고리즘 문제해결이 여러분을 마음고생시키지 않았으면 좋겠어요. 여러분의 문제해결을 항상 응원합니다.

solved.ac 화이트리스트 관련 입장 (5/8)

안녕하세요, solved.ac 운영자 박수현입니다. 여기는 운영 블로그는 아니고 개인 블로그입니다만 솔브드에는 글을 적기 마땅한 곳이 없어 여기에 적기로 했습니다.

solved.ac는 작년 7월에 클로즈 베타를 시작해 지금 시점으로 10개월째 가동되고 있습니다. 화이트리스트제 클로즈 베타의 형태로 사이트를 운영한 이유들은 아래와 같습니다.

  1. 사이트 초기에는 난이도가 붙어 있었던 문제들이 너무 적었고(서강대에서의 기여~2,000건), 제대로 된 난이도 기준이 없었기에 많은 사람들이 합리적이라고 생각할 수 있는 난이도 기준의 방향을 만들어가기 위해
  2. 스타트링크는 BOJ 스크레이핑을 공식적으로 허용하지 않고 있기 때문에, 사이트의 존재를 유지하기 위해 스크레이핑하는 유저의 수를 줄일 필요가 있어서

하지만 많은 사람들이 이 사이트를 통해 문제풀이에 재미를 붙이면 좋겠다고 생각했었고 그런 생각에서 난이도 조회만은 화이트리스트에 없더라도 누구나 할 수 있게 열어두었습니다.

이후 BOJ와의 통합이 결정됨에 따라 (2)의 영향이 줄어들어 화이트리스트를 천천히 늘려나갔습니다. 현재는 15,342명의 사용자가 화이트리스트에 등록되어 있습니다. 베타를 막 시작했을 8월의 3,517명과 비교하면 5배 가량 늘어난 것입니다.

그러나 개인 화이트리스트의 부작용이 있어 개인 화이트리스트 신청을 3월부터 중단하게 되었습니다. 아래와 같은 일들 때문입니다.

  • 개인 화이트리스트의 티어 조건을 맞추기 위해 다른 사람의 소스 코드를 베껴 제출하는 일이 빈번하게 일어났습니다. solved.ac와 BOJ 모두 이런 행위를 허용하고 있지 않으며, solved.ac는 이런 사례가 발견되는 대로 해당 유저를 화이트리스트에서 삭제했습니다.
  • 개인 화이트리스트 스크레이핑의 부담이 커졌습니다. solved.ac의 현재 사이트 구조는 단체 화이트리스트 스크레이핑이 훨씬 효율적으로 동작하도록 되어 있습니다.

악의적인 사용자들의 소스 복사/붙여넣기 행위에 대한 신고가 늘어서, 제가 개인 화이트리스트 제도를 만들지 않았다면 처리하지 않았어도 될 요청들을 처리하게 되어 저뿐만 아니라 스타트링크가 다른 기능들을 개발할 시간을 뺏기게 되었습니다. 통합 작업이나 새로운 기능을 개발하는 데 시간을 쏟는 편이 통합을 기다리는 사용자들에게 훨씬 이득이 될 것이라는 판단 하에 개인 화이트리스트를 더 이상 받지 않겠다는 결정을 했습니다.

이후 일부 BOJ 이용자 분들께 여러 비난과 질책(대체로 공정하지 않다는 의견들인 것 같습니다)을 받았고, 고심 끝에 남겨두었던 단체 화이트리스트도 오는 5월 16일을 마지막으로 더 받지 않으려 합니다. 다만 BOJ와 통합이 완료되면 화이트리스트와 상관없이 누구나 사이트를 이용할 수 있게 될 예정이므로 조금만 더 기다려 주시기를 부탁드립니다.

감사합니다.


추가로 아래는 사이트에 관해 자주 해 주시는 질문들과 그에 대한 제 답변입니다.

통합되면 어떤 점이 좋은가요? – 통합되면 베타가 끝납니다. 화이트리스트가 없어지고 누구나 로그인을 할 수 있게 됩니다. 지금은 유저와 단체마다 일정 갱신 주기가 있지만 통합 이후에는 문제를 푸는 즉시 경험치가 반영되도록 할 계획입니다.

연봉 얼만가요? / 얼마 받고 일하나요? – solved.ac는 전적으로 제 개인 프로젝트이며 기부금 이외에 뭔가를 받고 있는 것은 없습니다. 다만 운영 비용은 스타트링크에서 지원받고 있습니다.

API를 제공할 예정이 있나요? – 예정은 있습니다만 우선순위는 높지 않습니다. 주된 이유는 documentation을 작성할 시간이 부족하기 때문입니다. solved.ac의 컨텐츠를 이용해 뭔가를 만들고 싶으시다면 solved.ac 사이트 자체를 크롤링하는 것보다는 플러그인 소스 코드 역공학을 통해 undocumented API 엔드포인트를 알아내 활용해 주시기 바랍니다.

소스 코드 카피로 화이트리스트 신청이 반려 / 화이트리스트에서 삭제되었습니다. 통합 후 사이트를 정상적으로 이용할 수 있나요? – 로그인은 가능해지지만, solved.ac 운영 규칙에 따라 통합 후에도 65,535일간 경험치가 0으로 고정됩니다.

2019 ICPC Asia Seoul Regional에 다녀왔습니다

[mathjax]

ICPC regional 본선으로는 두 번째고, 서울 본선으로는 첫 번째입니다. 아이러니게도 첫 번째 리저널 본선은 2019년 방콕 리저널이었습니다.

2018년에는 제가 1학년이었고, 코드포스 레이팅도 블루였고, 결정적으로 알고리즘 문제해결 자체를 시작한 지 채 1년이 안 되었을 때였기 때문에 그냥 ‘대회가 이렇게 돌아가는 거구나~’를 느끼기 위해 귀여운 새내기 동기들과 같이 나갔었는데요, 겨울에 코드포스로 나름의 하드 트레이닝을 해서 레이팅을 2000까지 끌어올린 뒤 올해는 수상을 목표로 준비하게 되었습니다. 따라서 ICPC를 진지하게 준비해본 건 올해가 처음이었고 예선부터 본선까지의 준비 기록을 한 번 정리해 보려 합니다.

팀 연습

팀 연습이라는 것을 해 본 적이 없는 저였기 때문에 팀원들에게 예전에 어떻게 했냐고 물어봤는데, 기억이 어렴풋했던 것 같습니다. 그래서 제가 어떻게든 진행을 해 봤습니다.

날짜와 장소 정하기

팀 연습은 조금 늦게 시작했던 것 같습니다. 개강하고 나서(적어도 9월에) 3명이 모두 참가할 수 있도록 날짜와 시간을 잡았습니다. 장소는 학회 아니면 PC방, 시간은 매주 2회 오후 7시 반이었습니다.

서강대학교의 경우 컴퓨터공학과 실습실 4곳을 스터디 학회들(ICPC Team, Release, CSPC Lab, CNU)이 각각 관리하는데, 실습실에 수업이 없을 경우에는 컴퓨터공학과 학생들이 자유롭게 사용할 수 있도록 되어 있습니다. 실습실을 학과에서 정해진 개방 시간 이외에 개방하는 것은 학회 자율이기 때문에 저녁 7시 30분에 연습을 시작해 새벽 12시 30분까지 문제를 풀고 에디토리얼까지 보고 집에 갈 수 있는 나름 좋은 환경이었습니다. 다만 실습실에 수업이 있는 날에는 PC방에서 연습을 해야 했는데, 가격도 가격이었지만 시끄러운 환경에서 머리 쓰는 건 나름 고역이었습니다. 뭐 어쩔 수 없었지요.

플랫폼 정하기

연습은 처음엔 Codeforces Gym에서 Virtual contest에 참가하는 방식으로 하다가 언젠가부터 BOJ 그룹의 연습 기능을 이용하게 되었습니다.

Codeforces Gym

Codeforces Gym은 Ghost라는 기능을 제공합니다. 실제 대회의 제출 기록을 스코어보드에 반영한 것인데, 실제로 해당 대회에 참가했다면 순위가 어땠는지를 가늠할 수 있다는 것이 장점인 것 같습니다. 다만 팀 연습 초기에는 제가 셋을 고를 때 너무 쉬운 셋이나 너무 어려운 셋만 골라서 별로 의미가 없었고, 그래서 오히려 스코어보드를 보고 스트레스를 받지 않기 위해 + 쉬운 문제를 빨리 찾아내는 훈련을 하기 위해 BOJ로 옮겼습니다.

BOJ 그룹 연습. 당연히 연습 중에 solved.ac는 껐습니다.

BOJ 연습 기능은 정말 간단하기 때문에 딱히 설명할 건 없는 듯 합니다. 연습 시간을 설정하고 문제를 미리 등록해 두면 됩니다. 물론 스코어보드는 그룹 내부 인원이 해당 시간에 연습에 참여한 것밖에 안 나옵니다. 쉬운 문제를 못 찾겠다면 대회 진행 1~2시간 후에 대회 공식 사이트에서 최종 스코어보드를 띄워놓는 식으로 연습했습니다. 좋은 방법은 아니었던 것 같습니다.

셋 고르기

역시 저는 ICPC 리저널에 대한 지식이 전무했기 때문에 처음에는 말 그대로 아무거나 골라 풀었습니다. 첫 두 팀 연습은 ICPC 리저널 셋이 아니었습니다. 첫 번째는 사설 대회였고 두 번째는 KAIST RUN 대회였던 것으로 기억합니다.

뭔가 제가 고른 셋이 전부 엄청 쉽거나 아니면 엄청 어렵다 보니까 이대로는 안 되겠다 싶어서 인터넷에서 여러 글을 찾아봤습니다. 이후로는 koosaga님의 내가 문제풀이를 연습하는 방법에서 ICPC-style 부분을 많이 참고했고, 유럽 리저널 특히 NWERC 위주로 골라 풀었습니다. Subregional은 너무 쉬웠고, regional 위주로 골라 풀었던 게 가장 적절한 난이도였던 것 같습니다. BOJ 슬랙에서 추천받은 셋들도 풀었습니다.

그렇게 대회까지 총 13셋 정도를 풀었습니다. 개인적으로는 봄부터 연습을 시작했더라면 어땠을까 하는 후회도 없지 않습니다.

전략 세우기

혼자 나가는 대회가 아니다 보니 연습을 거듭할수록 누가 어떤 문제를 언제 풀지 스케쥴링하는 것도 상당히 중요하다는 걸 느꼈습니다. ‘분명히 이건 우리가 풀 수 있는 문제였는데 왜 못 풀었지?’ 같은 현상이 연습 중반까지 자주 일어났습니다. 대표적으로

  • 풀이는 맞는 거 같은데 자꾸 틀렸던 경우
  • 완벽한 풀이를 생각했는데, 다른 팀원이 디버깅을 하느라 시간이 다 가서 코드로 옮기는 것조차 하지 못했던 경우

가 있었습니다.

맞왜틀

첫 번째 경우에는 단순한 실수일 가능성이 크기 때문에, 보통 온사이트 대회에서는 코드 인쇄를 신청하고 다른 팀원이 다른 문제를 푸는 게 일반적입니다. 하지만 저는 그런 걸 몰랐고 더군다나 PC방에서는 인쇄가 안 되었기 때문에… PC방 모니터가 크다는 점을 이용해, 왼쪽에서는 다른 팀원이 다른 문제를 풀었고 오른쪽에서는 제 코드를 띄워 놓고 눈으로 디버깅했습니다. 온사이트에서 인쇄가 가능하다는 걸 빨리 알았으면 좋았을 것 같습니다.

두 번째 경우는 스케쥴링의 문제였습니다. 예를 들면 ‘나 E, F, H 풀이 생각났어!’인데 누군가 J를 계속 디버깅을 하는 케이스인 건데, J 때문에 E, F, H에 병목현상이 생겼습니다. 따라서 틀린 솔루션을 디버깅하는 것보다 확실한 솔루션을 짜는 쪽으로 우선순위를 뒀습니다. 그리고 컴퓨터는 한 명만 쓸 수 있기 때문에 최대한 컴퓨터 자리를 공석으로 두지 않도록 했습니다. 이렇게 전략을 짜니 ‘풀 수 있었는데 못 푼 문제’가 많이 줄었습니다.

실패로부터 배우기

마지막으로, 대회가 끝나면 에디토리얼을 꼭 읽었습니다. 우리가 알고 있는 테크닉이었는지, 알고 있었다면 어떤 걸 잘못해서 틀렸는지 분석했고, 모르고 있었다면 이런 테크닉도 있구나 하고 새로운 기술을 알아갔습니다. 모르던 테크닉이나 실수가 많았던 테크닉은 팀노트에 작성했습니다. 정작 대회에서는 팀노트가 필요없었던 것 같습니다만…

연습이 끝나고 풀지 못한 대회 문제들을 풀어보는 걸 업솔빙upsolving이라고 하는데, 에디토리얼을 다 읽고 어디서 틀렸는지 토론하다 보면 새벽 1시가 훨씬 넘었고, 낮에 다시 학교에 와야 했기 때문에 안타깝게도 무리였습니다. 여건이 된다면 이후 연습에서는 업솔빙까지 꼭 해보고 싶었습니다.

예선

예선은 가족같은 분위기의 학교에서 진행했습니다. 무려 학회 실습실. 항상 오던 곳이라 편안하게 칠 수 있을 줄 알았으나 서버 상태가 메롱이어서 편안하게 못쳤습니다. 여하튼.

예선 스코어보드

예선에서는 6문제를 빠르게 풀었습니다.

I. Registration (3분, shiftpsh): 2013년부터 꾸준히 나와 오고 있는 문제입니다. 아이디와 비밀번호를 출력하면 됩니다. 대회 시작 직후에 여기저기서 ‘야 등록 어딨어’ 같은 소리가 들렸던 거 같은데 제출 서버가 맛이 가서 의미가 없었습니다. 다들 등록 제출하느라 이런 거겠지 하고 생각했으나…

B. Balanced String (14분, semteo04): \(2^{\left\lfloor\frac{n+1}{2}\right\rfloor}\)를 계산하는 쉬운 문제였습니다. 쉬운 문제였는데 서버가 맛이 가서 실제로 푼 시각보다 5분쯤 늦게 제출하게 되었습니다.

H. Four Squares (24분, shiftpsh): 라그랑주의 네 제곱수 정리를 풀어본 적이 있어서 금방 짰습니다.

C. Byte Coin (32분, lvalue): 쉬운 그리디여서 금방 짰습니다. 역시 채점 서버 때문에 제출이 몇 분 늦어졌습니다.

L. Two Machines (73분, semteo04): 냅색 DP였습니다. 냅색이라는 건 알았는데 제가 풀이가 갑자기 생각이 안 나서 저는 못 짜겠다고 선언했습니다.

D. Canal (117분, shiftpsh): 제가 고민중이었는데, semteo04가 이분 탐색이라고 하길래 multiset을 믿고 짰습니다. 이 문제는 대회 서버 때문에 대회가 끝나고 나서도 한두시간 동안 채점 결과를 받아보지 못했는데, multiset이 터졌다는 다른 팀의 증언을 듣고 상심하고 여의도 불꽃놀이나 보면서 심신을 안정시키기로 했습니다.

서강대에서 서강대교까지는 그렇게 멀지 않기 때문에 학교에서 아무 생각 없이 서강대교까지 걸어가서 불꽃을 혼자 구경했습니다. 서강대교에 도착하기 직전에 채점 결과가 공개되었는데, 이 때 D가 맞았다는 걸 알게 되어 안도했습니다. 프리즈 전에는 9등이었다고 합니다.

이미지
프리즈 전 스코어보드

Convex hull trick이라는 걸 알고도 못 푼 J가 너무 아쉬웠는데, 팀노트 코드를 베끼려고 보니 팀노트에 적혀 있던 코드가 그냥 특공대 솔루션이었습니다. 이후 본선에는 보완해 들고 갔는데 본선에는 CHT 안 나오더라고요. 너무하네

A가 LR flow인 걸 몰랐던 것도 아쉬웠습니다. 근데 어차피 서버 나가서 코드를 더 짰어도 문제를 더 맞았을 확률은 희박했을 거라고 생각합니다.

빨리감기해서…

본선 전날

본선은 온사이트 대회고, 온사이트 대회에 가면 인터넷에서나 볼 수 있었던 많은 분들을 뵐 수 있기 때문에 전날에는 수다 떠느라 안타깝게도 따로 연습은 못 했습니다.

한양대학교의 Twitter HLD 팀, POSTECH의 JonMatTaeng 팀과 함께 대회 전날 저녁식사를 했습니다. 레스토랑 이름이 기억이 안 나는데 꽤 맛있었습니다. 서강대 앞에도 점포 내줘요.

연세대/이화여대 상권에 뭔가 다 몰려 있어서 서강대생들은 뭘 먹거나 뭘 하려면 신촌 쪽으로 내려가야 하는데, 여기도 건대 상권에 거의 다 몰려 있어서 아마도 세종대생들도 건대 쪽으로 내려와야 하는 게 아닐까 하는 생각을 했습니다. 제 생각이 맞다면 서강대와 세종대가 의외로 이런 비슷한 점이 있는 거 같습니다. 서강대가 학교 규모는 훨씬 작지만…

다음날 대회가 아침에 있어서, 근처 호텔에서 묵었습니다. 가고 싶은 공연이 있었지만 대회 일정 때문에 신청을 못 했는데, 알고보니 묵던 호텔 바로 옆 건물에서 하더랍니다. 나한테 왜 그래

본선

일단 일어나서 초콜릿 도핑을 많이 했습니다. 빼빼로데이 시즌이길래 페레로 로쉐 2+2 행사를 하고 있었는데 사재기해 둘걸 그랬네요…

팀원 중 한 명은 본선대회일에 쳐야 하는 시험 때문에 숙소에 안 오고 학교에서 공부를 하다가 늦잠을 잤습니다. 다행히도 택시아저씨께서 존경스러운 속도로 운송(?)해 주셔서 실격은 면했습니다.

본선 스코어보드

본선에서는 7문제를 풀었습니다. 개인적인 목표가 7문제였는데 달성해서 상당히 기뻤습니다. 추가로 C와 J를 처음으로 풀었습니다.

J. Triangulation (11분, shiftpsh, First to solve): A가 상당히 쉬운 문제였어서 lvalue가 바로 솔루션을 생각해내 구현을 시작했는데, 제가 J를 보다가 그림 하나를 그려보고…

이미지
J번 풀이 (재연)

…이게 다른 어떤 문제보다 구현이 훨씬 더 쉬울 거 같아서 인터셉트해 제출했습니다. 아이디어를 빨리 생각해내서 운좋게 퍼스트 솔브를 했습니다. 서버 이슈가 없어서 다행이라고 생각했습니다.

이미지
순간 1등

J를 푼 직후 아주 잠시동안 1위였습니다. 스크린샷을 찍어 뒀고 대회가 끝난 뒤 휴대폰으로 컴퓨터 화면을 찍었습니다.

A. Fire on Field (13분, lvalue): 구현하라고 하는 걸 구현하면 되는 쉬운 문제였습니다. 제가 J를 짜려고 인터셉트했을 때 A 코드도 거의 다 짜여져 있던 상태였으므로 바로 제출해 맞았습니다.

L. What’s Mine is Mine (36분, semteo04): 간단한 유형의 DP라서 semteo04가 금방 풀었습니다.

I. Thread Knots (47분, shiftpsh): 그림만 봐도 이분 탐색의 냄새가 나는 문제였습니다. 바로 뚝딱 짰습니다.

B. Gene Tree (103분, semteo04): Tree DP라는 건 알았는데 제곱이 섞여 있어서 식이 괴랄하게 나왔습니다. 제가 식을 열심히 전개하면서 ‘이렇게 분해해서 생각하면 되지 않을까?’ 같은 식의 말을 했더니 semteo04가 뭔가 생각난 듯 열심히 구현했고, 제출해서 맞았습니다.

H. Strike Zone (164분 +2, semteo04): Kadane’s와 세그먼트 트리를 잘 섞으면 되지 않을까 싶어서 일단 제가 짜서 두 번 제출했는데 틀렸습니다. 알고 보니 KOI 2014 중등부의 금광 문제와 똑같은 문제였습니다. lvalue와 저는 정보올림피아드 준비/출전 경험이 없어서 몰랐지만 경험이 있던 semteo04가 제 코드를 버리고 새로 짜 순식간에 맞췄습니다.

C. Islands (204분 +6, lvalue, First to solve): 남은 문제 중에 풀만한 문제가 없어서 lvalue가 잡았는데, 솔직히 왜 맞았는지 아직도 아는 사람이 없습니다. 풀이가 맞는 게 맞는지 아니면 데이터가 약한 건지…

K번 Washer는 뭔가 3차원을 다루는 거 같아서 제가 3차원 벡터 연산하는 코드를 짜고 있었는데, 대회 15분 전에 ‘평면으로 잘라서 \(\binom{100}{3}\times 2^3\) 브루트포싱하면 되지 않을까?’라는 생각이 들어서 그 방향으로 구현했으나 WA를 계속 받았습니다. BOJ에 데이터가 올라온 후 제가 같은 방법으로 다시 구현해서 제출했더니 AC를 받아서 너무 안타까웠습니다. 아마 외적을 잘못 구현했거나 출력 포맷을 잘못 지켰던 것 같습니다…

최종 순위는 팀 랭킹 15위, 학교 랭킹 8위였습니다. 서강대학교가 학교 순위가 1자리수였던 건 2015년(6위) 이후 4년만이라 결과는 만족스러웠습니다. 색깔과 닉네임을 붙여서 팀명을 지으면 수상한다는 전설도 지켰습니다(2017년 BlueJoker, 2015년 PurpleNoon).

개인적으로는 제가 푼 게 많지 않아서 + K를 결국 풀지 못해서 조금 아쉽긴 했습니다. 그래도 제가 어시스트를 많이 했으니 괜찮지 않았을까 싶어요 ..?

스코어보드를 시상식 이후에 공개하는 게 아쉬웠습니다. 꼭 이렇게 해야 했나… 그래도 본선대회 운영은 전반적으로 만족스러웠고(특히 CLion이 있었다는 점에서!), 다과와 저녁은 맛있었습니다. 감사합니다.

Image result for take my money
Take my money

사실 해외 리저널에 참가비가 있다는 건 방콕 대회 때문에 알았는데, 오히려 우리나라가 특이하게 참가비가 없었던 것이었습니다. 내년부터는 참가비가 생긴다는데, 참가비는 얼마든지 괜찮으니 예선 서버 이슈같은 문제만 되풀이되지 않았으면 좋겠습니다.

당분간 휴학할 예정이라 다음에는 2022년 혹은 2023년 리저널에 참가하게 되지 않을까 싶습니다. 팀명처럼 진짜 레드 만들어 와서 월드 파이널에 꼭 한 번 나가보고 싶네요!

수고하셨습니다. 🎈