سیستم مسابقات


در این سوال قصد داریم سیستم برگزاری آزمون آنلاین، (چیزی شبیه به Quera) طراحی کنیم.

این سیستم تنها قابلیت برگزاری یک آزمون را دارد و سوالات آزمون کوتاه‌پاسخ اند.

  • لیست سوالات آزمون
  • لیست ارسال‌ها
  • جدول امتیازات
  • داوری ارسال‌ها

پروژه اولیه🔗

پروژه اولیه را از اینجا دانلود کنید. ساختار فایل‌های این پروژه به صورت زیر است:

contest_initial
├─ app
│   ├─ Console
│   │   └─ Kernel.php
│   ├─ Database
│   │   ├─ Problem.php
│   │   ├─ Submission.php
│   │   └─ User.php
│   ├─ Exceptions
│   │   └─ Handler.php
│   ├─ Http
│   │   ├─ Controllers
│   │   │   ├─ Auth
│   │   │   │   ├─ ForgotPasswordController.php
│   │   │   │   ├─ LoginController.php
│   │   │   │   ├─ RegisterController.php
│   │   │   │   ├─ ResetPasswordController.php
│   │   │   │   └─ VerificationController.php
│   │   │   ├─ Controller.php
│   │   │   ├─ ProblemController.php
│   │   │   ├─ ScoreboardController.php
│   │   │   └─ SubmissionController.php
│   │   ├─ Middleware
│   │   │   ├─ Authenticate.php
│   │   │   ├─ CheckForMaintenanceMode.php
│   │   │   ├─ EncryptCookies.php
│   │   │   ├─ RedirectIfAuthenticated.php
│   │   │   ├─ TrimStrings.php
│   │   │   ├─ TrustProxies.php
│   │   │   └─ VerifyCsrfToken.php
│   │   └─ Kernel.php
│   └─ Providers
│       ├─ AppServiceProvider.php
│       ├─ AuthServiceProvider.php
│       ├─ BroadcastServiceProvider.php
│       ├─ EventServiceProvider.php
│       └─ RouteServiceProvider.php
├─ bootstrap
│   ├─ cache
│   └─ app.php
├─ config
│   ├─ app.php
│   ├─ auth.php
│   ├─ broadcasting.php
│   ├─ cache.php
│   ├─ database.php
│   ├─ filesystems.php
│   ├─ hashing.php
│   ├─ logging.php
│   ├─ mail.php
│   ├─ queue.php
│   ├─ services.php
│   ├─ session.php
│   └─ view.php
├─ database
│   ├─ factories
│   │   └─ UserFactory.php
│   ├─ migrations
│   │   ├─ 2014_10_12_000000_create_users_table.php
│   │   ├─ 2014_10_12_100000_create_password_resets_table.php
│   │   └─ 2018_10_17_214246_contest.php
│   └─ seeds
│       └─ DatabaseSeeder.php
├─ public
│   ├─ css
│   │   └─ app.css
│   ├─ js
│   │   └─ app.js
│   ├─ svg
│   │   ├─ 403.svg
│   │   ├─ 404.svg
│   │   ├─ 500.svg
│   │   └─ 503.svg
│   ├─ .htaccess
│   ├─ favicon.ico
│   ├─ index.php
│   └─ robots.txt
├─ resources
│   ├─ js
│   │   ├─ components
│   │   │   └─ ExampleComponent.vue
│   │   ├─ app.js
│   │   └─ bootstrap.js
│   ├─ lang
│   │   └─ en
│   │       ├─ auth.php
│   │       ├─ pagination.php
│   │       ├─ passwords.php
│   │       └─ validation.php
│   ├─ sass
│   │   ├─ _variables.scss
│   │   └─ app.scss
│   └─ views
│       ├─ auth
│       │   ├─ passwords
│       │   │   ├─ email.blade.php
│       │   │   └─ reset.blade.php
│       │   ├─ login.blade.php
│       │   ├─ register.blade.php
│       │   └─ verify.blade.php
│       ├─ layouts
│       │   └─ app.blade.php
│       ├─ problem.blade.php
│       ├─ problems.blade.php
│       ├─ scoreboard.blade.php
│       └─ submissions.blade.php
├─ routes
│   ├─ api.php
│   ├─ channels.php
│   ├─ console.php
│   └─ web.php
├─ storage
│   ├─ app
│   ├─ framework
│   │   ├─ cache
│   │   ├─ sessions
│   │   ├─ testing
│   │   └─ views
│   └─ logs
├─ tests
│   ├─ Feature
│   │   └─ Example1Test.php
│   ├─ CreatesApplication.php
│   └─ TestCase.php
├─ .editorconfig
├─ .env
├─ .env.example
├─ .gitattributes
├─ artisan
├─ composer.json
├─ composer.lock
├─ package.json
├─ phpunit.xml
├─ server.php
└─ webpack.mix.js
Plain text

جزئیات🔗

جدول‌های پایگاه داده به شرح زیر است:

users🔗

این جدول شامل اطلاعات کاربران است که در فیلد‌های زیر ذخیره شده اند :

  • id: شناسه‌ی کاربر
  • name: نام نمایشی کاربر
  • email: ایمیل کاربر
  • password: رمز کاربر

problems🔗

این جدول شامل اطلاعات پرسش‌ها است که در فیلد‌های زیر ذخیره شده اند :

  • id: شناسه‌ی پرسش
  • subject: عنوان پرسش
  • content: محتوای پرسش

submissions🔗

این جدول شامل اطلاعات ارسال‌ها است که در فیلد‌های زیر ذخیره شده اند :

  • id: شناسه‌ی ارسال
  • user_id: شناسه‌ی کاربر ارسال‌کننده‌ی پاسخ
  • problem_id: شناسه‌ی سوالی که ارسال برای آن انجام شده‌است.
  • answer: پاسخ ارسالی
  • status: وضعیت پاسخ
    • 0: به معنی داوری نشده
    • 1: به معنی داوری شده و درست
    • 2: به معنی داوری شده و غلط
  • submitted_at: زمانی که پاسخ ارسال شده‌است

بخش‌هایی از این سیستم پیاده‌سازی شده‌است و شما کافی‌ است بخش‌های زیر را پیاده‌سازی کنید:

پرسش‌ها🔗

در صفحه‌ی نخست سایت بخشی برای ورود به سایت و بخشی برای نمایش لیست پرسش‌های مسابقه باشد.

صفحه‌ی پرسش🔗

کاربر با کلیک بر روی هر یک از پرسش‌ها به صفحه‌ی پرسش برود که صفحه‌ی پرسش دو قسمت دارد.

  1. بخش نمایش پرسش که عنوان و متن پرسش را نشان بدهد.
  2. بخش ارسال پاسخ، در صورتی که کاربر وارد سایت شده‌بود، باید فرمی برای ارسال پاسخ به او نشان داده‌شود.

بخش ارسال پاسخ🔗

در صورتی که کاربر وارد سایت شده بود پاسخ او به عنوان یک sumbission داوری نشده ثبت شود و به صفحه‌ی ارسال‌ها منتقل شود و در غیر این‌صورت خطای ۴۰۳ بدهد.

صفحه‌ی ارسال‌ها🔗

در صورتی که کاربری وارد سایت شده‌بود در این بخش تمام ارسال‌های انجام شده توسط خودش را ببیند در غیر این‌صورت خطای ۴۰۳ بدهد.

رتبه‌بندی🔗

در این صفحه لیست رتبه‌بندی تمام کاربران شامل رتبه‌ی آن‌ها، پنالتی گرفته شده و تعداد پرسش‌های حل شده‌ی هر کاربر نمایش داده می شود.

منظور از پنالتی یک کاربر مجموع پنالتی پرسش‌هایی که کاربر توانسته در انتها به آن‌ها پاسخ بدهد است.

پنالتی یک پرسش حل‌شده مثل pp برای کاربری مثل uu برابر با زمان ثبت اولین ارسال درست برای آن پرسش توسط uu از زمان شروع مسابقه به دقیقه، به‌اضافه‌ی بیست برابر تعداد ارسال‌های غلط ثبت‌شده توسط uu برای پرسش pp قبل از زمان ارسال اولین پاسخ صحیح توسط uu برای پرسش pp است.

نفر aa از نفر bb رتبه بهتری دارد اگر تعداد پرسش‌های حل‌شده توسط aa از bb بیشتر باشد و در صورت برابری تعداد پرسش‌های حل‌شده، پنالتی کمتری داشته‌باشد.

دقت کنید که زمان شروع کانتست داخل فایل .env تنظیم شده‌است و تمام کاربران (چه ارسالی داشته‌اند یا نداشته‌اند) در رتبه‌بندی می‌آیند.

داوری🔗

با دستور php artisan judge باید داوری اجرا شود.

اولین ارسال داوری نشده به ترتیب زمان ارسال را برای داوری انتخاب می‌کند. سپس در صورت وجود ارسال، اطلاعاتی به شکل زیر نمایش می‌دهد:

Problem ID: {problem_id}
Answer: {answer}
Plain text

که {problem_id} شناسه‌ی سوالی است که ارسال برای آن انجام شده و {answer} پاسخ ارسالی است. سپس یک سوال با محتوا Is it OK? می‌پرسد که در صورتی که yes وارد شود ارسال به عنوان پاسخ صحیح علامت‌گذاری و در غیر این‌صورت به عنوان پاسخ غلط علامت‌گذاری می‌شود.

نکات🔗

  • شما مجاز به تغییر همه‌ی فایل‌های داخل پوشه‌ی app/ هستید.
  • حق تغییر در ساختار اصلی مدل‌ها را ندارید اما می‌توانید فیلد‌ها و ریلیشن‌های دلخواهتان را به آن اضافه کنید.
  • از viewها برای فهمیدن آن‌چه باید بنویسید کمک بگیرید.
  • پس از اعمال تغییرات کل پروژه به غیر از پوشه‌ی vendor را Zip کرده و ارسال کنید.
  • نام فایل Zip اهمیتی ندارد.
ارسال پاسخ برای این سؤال
در حال حاضر شما دسترسی ندارید.