- Pemrograman
- Pemrograman kompetitif
- Advent of Code
- MDTV
- Peramban web
- DeepSeek
- Sakti Wahyu Trenggono
- Grand Theft Auto V
- Grand Theft Auto Online
- San Andreas Multiplayer
Pemrograman kompetitif GudangMovies21 Rebahinxxi LK21
Pemrograman kompetitif adalah olahraga pikiran yang diadakan menggunakan internet atau jaringan lokal, di mana para peserta mencoba untuk memprogram sesuai dengan spesifikasi yang diminta, dalam waktu yang terbatas. Kontestan dari pemrograman kompetitif biasa disebut juga sport programmers. Pemrograman kompetitif diakui dan didukung oleh beberapa perusahaan perangkat lunak dan internet multinasional, seperti Google dan Facebook. Ada beberapa organisasi yang mengadakan kompetisi pemrograman secara teratur.
Sebuah kompetisi pemrograman biasanya melibatkan tuan rumah yang memberikan sejumlah masalah matematika dan logika, yang disebut juga sebagai teka-teki, kepada para kontestan (yang jumlahnya beragam mulai dari puluhan hingga ribuan orang), dan para kontestan ini diminta untuk menuliskan program-program komputer yang memiliki kemampuan untuk menyelesaikan setiap masalah yang diberikan. Penilaian sering kali berdasarkan jumlah masalah yang diselesaikan dan waktu yang dihabiskan untuk memprogram solusi yang benar, namun dapat juga dipengaruhi oleh faktor-faktor lainnya (kualitas dari keluaran yang dihasilkan, waktu untuk mengeksekusi program, ukuran dari program, dan lain-lain).
Sejarah
Salah satu dari kontes tertua yang pernah ada adalah International Collegiate Programming Contest (ICPC) yang pertama kali diadakan pada tahun 1970-an, dan telah berkembang hingga menyertakan 88 negara pada ICPC tahun 2011.
Dari tahun 1990 ke tahun 1994, Owen Astrachan, Vivek Khera, dan David Kotz menyelenggarakan salah satu dari kontes pemrograman pertama yang terdistribusi dan berbasis internet, terinspirasi dari ICPC.
Minat pada pemrograman kompetitif telah bertumbuh pesat sejak tahun 2000 seiring dengan perkembangan internet karena internet merupakan fasilitas yang digunakan untuk mengadakan kontes internasional secara online, mengatasi masalah geografis.
Gambaran umum
Tujuan dari pemrograman kompetitif adalah menulis kode sumber dari program komputer yang dapat menyelesaikan masalah-masalah yang diberikan. Sebagian besar masalah yang diberikan pada kompetisi pemrograman bertemakan matematika dan logika. Masalah-masalah tersebut termasuk salah satu dari kategori berikut: kombinatorik, teori bilangan, teori graf, teori permainan algoritme, geometri komputasi, analisis string, dan struktur data. Masalah-masalah terkait constraint programming dan kecerdasan buatan juga populer di beberapa kompetisi.
Terlepas dari kategori masalah di atas, proses menyelesaikan masalah dapat dibagi menjadi 2 langkah utama: membangun algoritme yang efisien dan mengimplementasikannya menggunakan bahasa pemrograman yang sesuai (bahasa pemrograman yang diizinkan pada setiap kompetisi dapat berbeda-beda). Ini adalah kemampuan yang paling sering diuji pada kompetisi pemrograman.
Pada sebagian besar kontes, penilaian dilakukan otomatis oleh komputer, biasanya dikenal sebagai judge. Setiap solusi yang dikirimkan oleh kontestan akan diuji oleh judge melewati serangkaian kasus uji (biasanya rahasia). Secara normal, soal-soal dari kontes memiliki sistem penilaian all-or-none, yang berarti kontestan akan mendapat skor jika dan hanya jika solusi yang mereka berikan berhasil melewati seluruh kasus uji yang diberikan oleh judge, dan tidak akan mendapat apa-apa jika ada paling tidak satu kasus uji yang gagal dilewati. Namun, ada beberapa soal yang memiliki sistem penilaian parsial, yang berarti kontestan akan mendapat skor tergantung dari jumlah kasus uji yang berhasil dilewati, kualitas dari hasil, atau kriteria lainnya. Pada beberapa kontes, kontestan hanya perlu mengirimkan output dari input yang diberikan, lalu judge cukup menganalisa output yang dikirimkan.
Online judge adalah tempat penilaian yang dilakukan secara daring. Online judge memiliki fitur ranklist yang menampilkan peserta yang memiliki jumlah solusi yang berhasil, dan/atau waktu tercepat untuk menyelesaikan masalah.
Kompetisi terkenal
Ada dua jenis format kompetisi: jangka pendek dan jangka panjang. Setiap babak kompetisi jangka pendek berlangsung dari 1 hingga 5 jam, sedangkan kompetisi jangka panjang ada yang berlangsung selama beberapa hari ataupun hingga beberapa bulan.
= Jangka pendek
=International Collegiate Programming Contest (ICPC) - salah satu kompetisi yang paling tua, untuk mahasiswa universitas dalam bentuk kelompok masing-masing 3 orang
Olimpiade Internasional dalam Informatika (IOI) - salah satu kompetisi tertua, untuk siswa sekolah menengah
American Computer Science League (ACSL) - kompetisi ilmu komputer dengan porsi tulisan dan pemrograman, untuk siswa SMP / SMA
CodeChef - kompetisi yang diadakan dari tahun 2009, ada tiga kontes yang diadakan setiap bulan dan kompetisi tahunan yang disebut CodeChef SnackDown
Codeforces - biasanya kontes dua jam, diadakan setiap minggu
Facebook Hacker Cup - kompetisi yang diadakan mulai tahun 2011, disediakan dan disponsori oleh Facebook
HackerRank - berbagai kompetisi
Gridwars - empat kompetisi yang diadakan antara tahun 2003 dan 2004.
Google Code Jam - kompetisi yang diadakan dari tahun 2003, disediakan dan disponsori oleh Google
IEEEXtreme Programming Competition - kompetisi tahunan untuk Anggota Mahasiswa IEEE yang diadakan sejak tahun 2006 oleh IEEE .
Topcoder Open (TCO) - Kompetisi algoritme yang diadakan sejak tahun 2001 oleh Topcoder
Untuk sebagian besar kompetisi-kompetisi di atas, karena jumlah kontestan yang mengikutinya cukup banyak, maka biasanya kompetisi-kompetisi tersebut dibagi menjadi beberapa babak. Babak tersebut biasa diadakan secara online terkecuali babak terakhir, yang diadakan di tempat. Sebuah pengecualian khusus untuk ini adalah IEEEXtreme yang merupakan kompetisi pemrograman virtual tahunan yang berdurasi selama 24 jam. Para kontestan terbaik IOI dan ICPC mendapatkan medali emas, perak, dan perunggu, sedangkan di kontes-kontes lainnya para pemenang diberi hadiah uang tunai. Selain itu, mendapatkan peringkat atas pada papan skor dalam kompetisi-kompetisi semacam ini juga dapat menarik minat para perekrut dari perusahaan perangkat lunak dan Internet.
= Jangka panjang
=HackerRank Week of Code
ICFP Programming Contest - kompetisi tahunan berdurasi 3 hari yang diadakan sejak tahun 1998 oleh International Conference on Functional Programming
Topcoder Marathon Matches
Codechef Long Challenges - diadakan setiap bulan - berlangsung paling lama 10 hari
Kecerdasan buatan dan pemelajaran mesin
Kaggle – kompetisi pemelajaran mesin.
CodeCup – kompetisi kecerdasan buatan permainan papan yang diadakan secara tahunan sejak tahun 2003. Aturan permainan diumumkan pada bulan September dan turnamen finalnya diadakan pada bulan Januari.
Google AI Challenge – kompetisi yang diadakan dua kali setiap tahun untuk mahasiswa yang berlangsung dari tahun 2009 hingga 2011
Halite – Sebuah tantangan pemrograman kecerdasan buatan yang disponsori oleh Two Sigma, Cornell Tech, and Google
Russian AI Cup kontes pemrograman kecerdasan buatan terbuka
= Kontes yang berfokus pada teknologi open source
=Daftar mungkin tidak lengkap
Kontes online dan sumber latihan
Komunitas pemrograman di seluruh dunia telah membuat dan memelihara beberapa sumber daya di Internet yang didedikasikan untuk pemrograman kompetitif. Sumber daya tersebut mengadakan kontes-kontes mandiri dengan atau tanpa adanya hadiah kecil. Arsip yang berisi masalah-masalah dari kompetisi di masa lampau juga merupakan sumber daya yang populer untuk berlatih dalam pemrograman kompetitif. Sumber daya tersebut termasuk:
Manfaat dan kritik
Partisipasi dalam kontes pemrograman dapat meningkatkan antusiasme siswa terhadap bidang studi ilmu komputer. Kemampuan yang didapatkan dari kontes pemrograman seperti ICPC juga meningkatkan prospek karir kedepannya, karena kemampuan tersebut dapat berguna untuk mengerjakan soal-soal interview kerja, yang sering kali kandidat diminta untuk menyelesaikan masalah pemrograman kompleks dan algoritme secara langsung.
Namun ada juga kritik terhadap pemrograman kompetitif yang secara spesifik disampaikan oleh pengembang perangkat lunak profesional. Salah satu poin penting yang disampaikan adalah banyak kompetisi pemrograman serba cepat yang mengajarkan kompetitornya kebiasaan pemrograman dan gaya kode yang buruk. Contohnya seperti penggunaan makro yang tidak perlu, kurangnya abstraksi pemrograman berorientasi objek, kode komentar yang menjelaskan isi dari kode tersebut, penamaan variable yang pendek, dan lain-lain. Selain itu, dengan hanya menawarkan permasalahan algoritmik yang kecil dengan solusi yang relatif singkat, kompetisi pemrograman seperti ICPC dan IOI tidak serta merta mengajarkan keterampilan dan praktik rekayasa perangkat lunak yang baik, sedangkan proyek perangkat lunak pada dunia kerja biasanya memiliki ribuan baris kode dan dikembangkan oleh tim besar dalam jangka waktu yang lama. Peter Norvig menyatakan bahwa berdasarkan data yang tersedia, menjadi pemenang dari kontes pemrograman berkorelasi negatif dengan kinerja pemrogram pada pekerjaannya di Google. Meski demikian, pemenang kontes memiliki peluang lebih tinggi untuk mendapatkan pekerjaan.
Ada juga sentimen lain yang berkata bahwa daripada membuang-buang waktu dengan berkompetisi secara berlebihan menyelesaikan masalah yang solusinya sudah ada, pemrogram lebih baik menginvestasikan waktu mereka dengan menyelesaikan dunia nyata.
Literatur
Halim, S., Halim, F. (2013). Competitive Programming 3: The New Lower Bound of Programming Contests. Lulu.
Laaksonen, A. (2017). Guide to Competitive Programming (Undergraduate Topics in Computer Science). Cham: Springer International Publishing.
Lihat juga
Kompetisi ilmu komputer
Kode golf
Referensi
Pranala luar
Proyek sumber terbuka untuk menjalankan kontes
Contest Management System Alat sumber terbuka yang dibuat dengan Python untuk menjalankan dan mengelola kontes pemrograman di sebuah server IOI 2012 dan IOI 2013.
Kata Kunci Pencarian:

Does Competitive Programming Make You a BETTER Programmer? - YouTube

The Best Competitive Programmer in the US - YouTube
Pemrograman Kompetitif Dasar Full C++ | PDF
Pemrograman Kompetitif Dasar | PDF
Pemrograman Kompetitif Dasar - 04 Divide and Conquer | PDF
Pemrograman Kompetitif Dasar - 02 Matematika Diskret Dasar Kombinatorik ...
GitHub - joangerard/competitive-programming
GitHub - Mahmoud-kh1/competitive-programming

Competitive Programmer’s Handbook – Online Course School
jawaban-toki/Kompetitif Dasar/01. Perkenalan Pemrograman Kompetitif ...

Competitive Programming Guide | PPT

What Is Competitive Programming? Definition, Uses