SPOJ - SPOJ

SPOJ (Sphere Online Judge) - bu an onlayn sudya 315,000 dan ortiq foydalanuvchilar ro'yxatdan o'tgan va 20,000 dan ortiq muammolarga ega tizim. Vazifalar uning jamoalari tomonidan tayyorlanadi yoki oldingi dasturiy tanlovlardan olingan. SPOJ ilg'or foydalanuvchilarga o'z qoidalari bo'yicha tanlovlarni tashkil qilish imkoniyatini beradi, shuningdek, dasturchilar muayyan muammoni qanday hal qilishni muhokama qilishi mumkin bo'lgan forumni o'z ichiga oladi.

Tashqari Ingliz tili, SPOJ shuningdek o'z tarkibini taqdim etadi Polsha, Portugal va Vetnam tillar. Muammolarni hal qilish uchun 40 dan ortiq dasturlash mumkin tillar, shu jumladan, Ezoteriklarni, Sphere Engine orqali. Uni Polshaning Sphere Research Labs kompaniyasi boshqaradi.[1]

Veb-sayt ham foydalanuvchi tomonidan taqdim etilgan dasturlarning avtomatlashtirilgan baholovchisi, ham odamlarga hisoblash vazifalarini tushunishda va hal qilishda yordam beradigan onlayn o'quv platformasi hisoblanadi.[2] Shuningdek, bu o'quvchilarga turli xil tillar bilan paradigma va yondashuvlarni solishtirishga imkon beradi.

Tarix

Ushbu tizim dastlab talabalarni o'qitishda onlayn sudyani qo'llash uchun yaratilgan. Bu asosan universitetlarning talabalari va o'qituvchilariga va algoritmlar va dasturiy tanlovlarga qiziqadigan keng dasturlash hamjamiyati a'zolariga qaratilgan.

Maqsadlar

U turli xil foydalanuvchilarga turli maqsadlar uchun mo'ljallangan, masalan:[3]

  • Algoritmlarni tushunishni rivojlantirish uchun yoshlar va boshlang'ich dasturchilar uchun.
  • Universitet talabalariga uy vazifalarini halol, puxta va aldovsiz bajarish imkoniyati beriladi.
  • ACM tanlovining ijobiy tomonlari vazifalarni juda kam dasturlash tillari cheklovlari yoki noqulay foydalanuvchi interfeysi bilan cheklanmasdan hal qilishlari mumkin.
  • Funktsional yoki ob'ektga yo'naltirilgan dasturlashning ixlosmandlari tanlov muammolarini o'zlarining sevimli tillarida hal qilishlari mumkin.
  • SPOJ jamoatining qolgan a'zolari bilan qiziqarli vazifani baham ko'rishni istagan har bir kishi buni deyarli avtomatik ravishda amalga oshirishi mumkin (administratorga muammolarni hal qilish imtiyozlarini so'rab bitta xat yuborish kifoya),
  • Dasturlash tanlovini tashkil qilishni istagan har qanday shaxs, qaror qabul qilishi mumkin bo'lgan deyarli barcha qoidalar bilan, tizim ma'murlari yordamisiz xohlagan vaqtda buni amalga oshirishi mumkin.

Muammo toifalari

SPOJdagi arxivlangan muammolar 5 toifaga bo'lingan:[4]

  • Klassik: Bu ikkilik darajadagi muammolar. Qabul qilingan yoki noto'g'ri javob[iqtibos kerak ]
  • Qiyinchilik: Ular foydalanuvchilarga yomonroq yoki yaxshiroq echimlarni taklif qilishlariga imkon beradi. Muayyan muammoga aniq javoblar yo'q
  • Qisman: Bular muammolarni echishga o'xshaydi, ammo ta'lim maqsadiga ega
  • Qo'llanma: Klassik muammolar singari, ammo osonroq bo'lganlar, ular ta'lim maqsadlari uchun, masalan, keng tarqalgan algoritmni o'z ichiga oladi
  • Topishmoq: Jumboqlarni o'z ichiga olgan muammolar

Muammoni yanada qiyinlashtirishi uchun taqdim etishda cheklovlar bo'lishi mumkin. Bunga tillarning mavjudligi (masalan, faqat ezoterik tillar) va hisoblash vaqti kiradi.

Hukm qilish

Klasterlar

Taqdimotlar bittadan baholanadi klaster:[5]

  • Kub (Intel Xeon E3-1200 v5): Saytda "ushbu yangi klaster zamonaviy va tezkor Intel Xeon E3-1220 v5 protsessorlaridan iborat. Kubda sizning taqdimotlaringiz" Piramida "ga qaraganda 30 dan 50 baravar tezroq ishlaydi, shuning uchun siz o'zingizning qaroringizni uyda sinab ko'rsangiz, u holda SPOJ-da ham xuddi shunday bajarilish vaqti bo'ladi. Ushbu klasterda taqdim etish uchun 1536 MB xotira chegarasi mavjud. " Piramida klasteri o'chirilgan.

Dasturlar ma'lum bo'lgan to'g'ri javob bilan taqqoslash yo'li bilan yoki har bir muammoning o'ziga xos hakamlik kodini ishga tushirish orqali tekshiriladi.[2] Keyinchalik murakkab muammolarda bir nechta javoblar bo'lishi mumkin bo'lsa, bu tobora ko'proq zarur bo'lib qolmoqda. Kompyuterdan foydalangan holda markirovka izchil, adolatli va samaradorlikni real vaqtda, odamlarning fikriga qaraganda o'lchashi mumkin.

Tizimning samarali ishlashini ta'minlash uchun Linux buyruqlari RLIMIT_CPU yomon ishlab chiqilgan testlarning boshqalarga ta'sir qilishini to'xtatadi. Chroot () tizim qo'ng'irog'i fayl tizimining qum qutilaridan foydalangan holda dasturlarning ishlashiga cheklovlar qo'yadi: masalan, sleep () buyrug'iga ruxsat berilmaydi, chunki u mavjud xotirani kamaytiradi.

Veb-saytning qulay, erkin va ob'ektiv xususiyati talabalarga avvalgi yutuqlar asosida mantiqiy va dizayn tajribalarini to'plash imkonini beradi. Biroq, tizim kodlarning sifati, hujjatlari yoki boshqa sub'ektiv xususiyatlarini baholamaydi, bu haqiqiy dunyo dasturlari uchun muhimroq bo'lishi mumkin.

Taqdim etilganidan so'ng, foydalanuvchiga kodni ishga tushirish yoki kompilyatsiya qilish paytida xatolik yuz berganligi to'g'risida xabar beriladi; muddat oshib ketdi; noto'g'ri javob chiqarilgan yoki to'g'ri bo'lgan. Qiyinchilik muammolarining javoblari ball bilan birga keltirilgan (pastga qarang).

Skorlama

Ballar masalalar bo'linadigan toifaga qarab beriladi.[6]

  • Klassik: Bitta muammo bo'yicha bal ochkolar.
  • Qiyinchilik: Bal quyidagicha ikkita mezonga ega:
    • har qanday qiyinchilikda eng yuqori ball uchun: 3 ball,
    • qiyinchilikdagi har qanday past ball uchun: (foydalanuvchining eng yuqori ballga nisbatan ballari) ball.
  • Qisman: 0 ball
  • Qo'llanma: 0 ball
  • Topishmoq: 0 ball

"Qiyinchilik" toifasi uchun ballar odatda topshirish hajmi baytlarda bo'ladi, ammo har xil bo'lishi mumkin. Masalan, bu doimiy doimiy o'nlik kasrlar soni bo'lishi mumkin.

Izoh: SPOJ tez-tez ballarni hisoblash uchun ishlatiladigan formulalarni o'zgartiradi

Dasturlash bo'yicha tanlovlar

SPOJ keng miqyosli musobaqalar uchun maydon sifatida ishlatiladi, mahalliy darajadan xalqaro darajagacha va qisqa soatlik muammolardan bir yilgacha davom etadigan ligalargacha. Ishtirokchilar odatda turli xil tillarda gaplashadilar, shuning uchun sayt yanada teng sharoitlarni ta'minlaydi, shuningdek tashkilotchilarning ish yukini kamaytiradi.[2]

Tanqid

Onlayn hakamlar tizimining foydalanuvchilari hujjatlashtirish va yaxshi tuzilgan kodni yaratish uchun unchalik rag'batlantirmaydilar, ehtimol ularni musobaqalardan tashqarida hisoblashning odatiy dasturlari uchun kamroq tayyor bo'lishlari mumkin.[2]

Da o'tkazilgan tadqiqot natijalari Gdansk Texnologiya Universiteti[2] Universitet sharoitida berilgan muddat, shu jumladan topshiriq topshirilganiga qarab bonus va jarima ballari, bir xil kod taqdim etilgan taqdirda ham, yaxshi tashkil etilmagan talabalarga nisbatan qattiqqo'llik bilan munosabatda bo'lishni taklif eting. Bu talabalarga motivatsion ta'sirlarni aralashtirib yubordi, ba'zilarini belgilangan muddat bilan ishlashga undaydi, boshqalarning ma'nosini pasaytirmoqda. Xuddi shu tadqiqot shuni ko'rsatadiki, onlayn sudyalar tizimidan foydalanish talabalar va xodimlar o'rtasidagi aloqani pasayishiga olib keladi. Ammo, o'qitishga yuqori yuk bilan ishlaydigan xodimlarga nisbatan, bu qisqartirish xodimlarga o'z vaqtlarining ko'p qismini qiyinchiliklarga duch kelgan talabalarga bag'ishlashi mumkin, bunda baholash bilan bog'liq ma'muriy ortiqcha xarajatlar va yordamga muhtoj bo'lmagan talabalar bilan munozaralarga sarf qilingan vaqt yo'q qilinadi.

Tillar

SPOJ foydalanuvchilar o'z echimlarini taqdim etishi mumkin bo'lgan 60 ga yaqin tilni qo'llab-quvvatlaydi. Ular:

Ada, Assembler, AWK, Bosh, Brainfuck, C, C ++ va C99 qattiq, C #, Klojure, Umumiy Lisp, D., Hujjat (sinovsiz), Erlang, Fortran, F #, Boring, Xaskell, Belgisi, Interkal, Jar, Java, JavaScript, Lisp, Lua, Nemerle, Yaxshi, Node.js, OCaml, Paskal, PDF, Perl, PHP, Payk, PostScript, Prolog, Python, Yoqut, Zang, Scala, Sxema, sed, Kichik munozarasi, Tcl, Tecs, Text va Bo'shliq.

Shuningdek qarang

Adabiyotlar

  1. ^ "Sfera tadqiqot laboratoriyalari huquqiy ma'lumotlar". Sfera tadqiqot laboratoriyalari. Olingan 2015-06-21.
  2. ^ a b v d e Kosovski, Adrian; Malafeyskiy, Mixal; Noinski, Tomasz (2008-04-14). Internetga asoslangan ta'lim sohasidagi yutuqlar - ICWL 2007: 6-xalqaro konferentsiya, Edinburg, Buyuk Britaniya, 2007 yil 15-17 avgust, Qayta ko'rib chiqilgan maqolalar. Springer Science & Business Media. p. 344. ISBN  9783540781387.
  3. ^ Kosovski, Adrian (2004 yil 3 sentyabr). "SPOJ ning _maqsadi_ nima?". SPOJ. Olingan 22 sentyabr, 2014.
  4. ^ "MUAMMOLAR". SPOJ. Olingan 22 sentyabr, 2014.
  5. ^ "Klasterlar". SPOJ. Olingan 24 sentyabr, 2017.
  6. ^ "Foydalanuvchilar statistikasi". SPOJ. Olingan 22 sentyabr, 2014.

Tashqi havolalar