مشخصات

زبان

C++

بانک اطلاعاتی

فایل ها

cpp

۳۳,۰۰۰ تـــــومان

سورس بازی سودوکو با زبان C++

  • یکشنبه ۲۴ آذر ۱۳۹۸
  • بازدید ۳,۸۴۷ نفر

تصویر cpp-sudoku-source-code_7469 سورس بازی سودوکو با زبان C++

سورس بازی سودوکو با زبان C++

در این بخش سورس بازی سودوکو با زبان ++C را برای شما آماده کرده ایم که با استفاده از زبان برنامه نویسی C++ نوشته شده است. در ادامه می توانید توضیجات، بخشی از سورس کد، تصاویری از خروجی پروژه و فیلمی از نحوه اجرای برنامه را مشاهده کنید.

بازی سودوکو (sudoku)

سودوکو یکی از بازی های مشهور و پرطرفدار است که در اکثر کشورها بازی می کنند. محیط این بازی یک جدول 9×9 است که جدول های 3×3 را شامل می شود. در ابتدای بازی در خانه های مختلف اعدادی قرار داده می شود که باید با توجه به آن ها مقدار سایر خانه ها را نیز مشخص کنیم. در زیر می توانید قوانین مربوط به چگونگی پر کردن خانه های باقی ماننده را مشاهده کنید:

  • در هر سطر و ستون از جدول باید اعداد 1 تا 9 بدون تکرار قرار گیرند.
  • در هر ناحیه 3×3 از جدول باید اعداد 1 تا 9 بدون تکرار قرار گیرند.

روش حل

در گام اول در همه خانه های خالی جدول، عدد ها را از 1 تا 9 قرار می دهیم. سپس به سراغ اعدادی که به صورت پیشفرض تولید شده اند، می رویم و همه اعداد شبیه به آن که در عرض (بصورت افقی) قرار گرفته‌اند، را حذف کرده و یک خط افقی در بالای آن عدد می‌کشیم که مشخص باشد.

در این مرحله مانند مرحله اول عملیات را انجام می دهیم به جزء این که در همه خانه های عمودی در بالا یا پایین عدد مورد نظر اعداد شبیه به هم را حذف می کنیم و بعد با یک خط عمودی در کنار آن عدد، آن را مشخص می نماییم. اعداد مشابه عدد مورد نظر را در مربع نه خانه ای متناظر، حذف می کنیم و عدد را با یک دایره بر دور آن مشخص می کنیم.

دقت کنید که سه مرحله گذشته را در مورد همه عدد های از قبل نوشته شده تکرار کنید. کشیدن خط های عمودی افقی و دایره را بر آن عددها باعث می شود که اعدادی که باقی مانده اند مشخص شوند.

زمانی که کل عدد های چاپی با هر سه علامت مشخص شدند کار ما تا این مرحله تمام می شود. در این مرحله به دنبال خانه هایی می‌گردیم که فقط یک عدد در آنها باقییمانده و آن اعداد را پررنگ می کنیم. باید در هر ستون عددی را که فقط یکبار در آن ستون آمده است را پیدا کرده و این عدد قطعا جواب همان خانه خواهد بود و این عدد را هم پررنگ می کنیم. اکنون در هر مربع نه خانه ای عددی را که فقط یکبار در این نه خانه آمده است را یافته و به عنوان جواب یک جای می کنیم.

اگر روش فوق سخت است می توانید از این روش نیز استفاده کنید. توجه کنید که هر عدد در هر مربع یک بار استفاده می شود و جدول ما دارای 9 تا از مجموعه خانه های مربع شکل 3×3 است به خاطر همین هر عدد علاوه بر اینکه در هر ردیف و هر ستون یک بار استفاده می شود در هر مربع نیز یک بار مورد استفاده قرار می گیرد.  پس اگر عددی در یک مربع بزرگ پیدا شد باید بررسی کنید و معادل آن عدد را در مربع بزرگتر را در همان ردیف و یا همان ستون پیدا کنید، اگر آن را پیدا کردید یک خط فرضی از آن عدد از هر مربع بصورت افقی و یا عمودی بکشید با این کار دو ستون و یا دو ردیف از مربعی که عدد در آن موجود نبوده از محاسبات حذف می شوند و فقط سه خانه از آن مربع باقی می ماند. همین کار را هم از طرف مقابل از همان عدد انجام دهید یک خانه خالی باقی خواهد ماند که جای همان عدد است. معمولاً با این کار بیشتر خانه های خالی پر می شوند که مابقی را از طریق اسکن کردن سطر به سطر و یا ستون به ستون می توان بدست آورد.

قسمت های از سورس کد

 

 

تصویر 1
باکس دانلود
شناسه:
۷۴۶۹
زبان:
C++
فایل ها:
cpp
قیمت:
۳۳,۰۰۰ تـــــومان
ثبت نظر
ریفریش کنید!
نظرات کاربران (۰ مورد)

هیچ نظری ثبت نشده است