Skip to main content

Panduan Membuat Slug Soal

Setiap soal pada TLX memiliki sebuah identifier (pengenal) berupa sebuah string yang disebut slug, yang harus berbeda-beda. Biasanya, slug dibentuk dari judul soal, misalnya tebak-angka.

Saat ini terdapat banyak kontes pada TLX. Mungkin saja ada dua soal dari dua kontes berbeda yang memiliki judul yang sama. Sebagai contoh, Tebak Angka adalah judul soal yang lumayan umum. Menggunakan tebak-angka sebagai slug tentu bukanlah ide yang baik.

Dokumen ini ditulis agar dua soal yang berbeda (walaupun dengan judul soal yang sama) tidak memiliki slug yang sama, dan gayanya konsisten.

1. Aturan Umum

Slug harus terdiri atas beberapa kata yang dipisahkan oleh -. Setiap kata harus tersusun atas satu atau lebih karakter huruf kecil, angka, atau keduanya.

  • Contoh 👍: a-plus-b, tree-reconstruction, 2sat-construction.
  • Contoh : a+b, tree--reconstruction, 2SAT-construction.

2. Soal Kontes

2.1. Soal Kontes yang Sudah Lewat atau Akan Datang

Jika Anda ingin meletakkan:

  • soal pada kontes yang sudah lewat, misalnya untuk arsip soal ICPC,
  • soal baru untuk digunakan pada kontes yang akan datang, misalnya TROC bulan depan,

maka slug soal harus mengikuti format berikut:

<nama kontes>-<nama soal>

Contoh 👍: ksn-2020-mencari-bola, icpc-jakarta-2020-police, troc-22-near.

  • 2.1.2. Bagian <nama kontes>

    Bagian ini harus mengidentifikasikan kontes secara unik pada TLX. Selain itu, kontes yang serupa sebaiknya memiliki format yang serupa. Sebagai contoh, format untuk kontes TOKI Open Contest selalu berupa toc-<tahun>-<bulan>.

    • Contoh 👍: ksn-2020, icpc-jakarta-2020, troc-22, toc-2018-feb.
    • Contoh : ksn, icpc-jakarta, troc, toc-2018.
  • 2.1.3. Bagian <nama soal>

    Bagian ini harus mengidentifikasikan soal secara unik pada kontes di mana soal ini digunakan. Sebaiknya terdiri atas satu atau dua kata kunci yang diambil dari judul soal.

    • Contoh 👍: mencari-bola, police, near
    • Contoh : a, b, pohon-merah-hitam, daratan-dan-es

2.2. Modifikasi dari Soal Kontes yang Sudah Lewat

Jika Anda memodifikasi soal kontes yang sudah lewat, misalnya:

  • batasan dari soal asli diubah menjadi soal modifikasi yang menjadi lebih sulit (atau lebih mudah),
  • soal asli menggunakan penilaian ICPC (tidak terdapat subsoal) dan dimodifikasi menjadi soal yang menggunakan penilaian IOI (terdapat subsoal),

maka slug soal modifikasi ini harus mengikuti format berikut:

  • <slug-soal-asli>-modified
  • <slug-soal-asli>-modified-<indeks> (jika terdapat lebih dari satu modifikasi)

Sebagai contoh, soal modifikasi pada soal troc-22-near memiliki slug:

  • troc-22-near-modified
  • troc-22-near-modified-2 (modifikasi kedua)

3. Soal Lainnya

3.1. Soal Belum Terpakai

Jika soal bukan/belum merupakan kontes pada TLX, maka slug harus diawali dengan <username TLX Anda>-. Jika username TLX Anda memiliki karakter yang bukan merupakan karakter huruf kecil atau angka, maka Anda harus mengabaikan karakter-karakter tersebut.

Sebagai contoh, jika username TLX Anda adalah dengklek, lalu Anda membuat soal pribadi yang belum dipakai untuk kontes apapun berjudul Halo Dunia, maka Anda dapat menggunakan slug dengklek-halo-dunia. Jika nantinya soal ini digunakan untuk suatu kontes (misalnya TROC), Anda dapat mengganti slugnya.

Contoh 👍: dengklek-halo-dunia.

3.2. Soal Coba-Coba

Jika Anda membuat soal yang digunakan untuk mencoba-coba saja, maka slug soal harus diawali dengan <username TLX Anda>-TESTING.

Diharapkan untuk meminimalkan banyaknya soal coba-coba yang Anda buat. Jika Anda sudah pernah membuat soal coba-coba sebelumnya dan ingin melakukan coba-coba kembali, gunakan ulang soal coba-coba yang sudah Anda buat sebelumnya.

Contoh 👍: dengklek-TESTING-grader.

3.3. Soal Tidak Dipakai

Jika soal yang Anda buat sudah tidak dipakai lagi (misalnya Anda membuat kesalahan commit dan tidak bisa di-revert), maka slug soal harus diawali dengan <username TLX Anda>-UNUSED.

Soal dengan slug yang mengandung substring UNUSED dapat dihapus kapan saja dari TLX jika dibutuhkan (misalnya jika TLX kehabisan storage).

Contoh 👍: dengklek-UNUSED-commit-error.