تبلیغات :
ماهان سرور
آکوستیک ، فوم شانه تخم مرغی ، پنل صداگیر ، یونولیت
فروش آنلاین لباس کودک
خرید فالوور ایرانی
خرید فالوور اینستاگرام
خرید ممبر تلگرام

[ + افزودن آگهی متنی جدید ]




نمايش نتايج 1 به 4 از 4

نام تاپيک: تعیین مربع کامل بودن

  1. #1
    داره خودمونی میشه
    تاريخ عضويت
    Dec 2014
    پست ها
    45

    پيش فرض تعیین مربع کامل بودن

    برنامه ای که عددی راازورودی دریافت کند وتعیین کندکه ایا مربع کامل است یاخیر

  2. #2
    آخر فروم باز hamed29's Avatar
    تاريخ عضويت
    Oct 2009
    محل سكونت
    سیاره زمین
    پست ها
    1,567

    پيش فرض

    الگوریتم 1
    میتونید اول جذر رو به دست بیارید و بعد ببینید آیا مجذور یک عدد طبیعی هست یا نه.
    مثلاً عدد 36 میشه 6، که یک عدد طبیعی هست.
    ولی اگه از 37 جذر بگیریم، جواب اعشاری میشه؛ پس 37 مربع کامل نیست.

    برای بررسی طبیعی بودن عدد از مقایسه آن با براکت (جزءصحیح) استفاده میکنیم.
    اگر جزء صحیح یک عدد با خودش برابر باشه، اون عدد طبیعی هست.دستور جزء صحصیح : floor

    مثلاً اگه 5.5 رو با جزء صحیحش مقایسه کنیم، با هم برابر نیستن. چون جزء صحیحش میشه 5 !
    یعنی: [5.5] ≠ 5.5



    الگوریتم 2
    اما روش بالا مثل چرخوندن لقمه دور سر هست. بنابر این شما فایل txt زیر رو دانلود کنید.
    برنامه به زبان پاسکال هست اما الگوریتمش فرق نمیکنه. پس شما همین رو به C++ تغییر بدید.
    میخواستم اینجا کپی کنم متنش به هم میریخت!

    [ برای مشاهده لینک ، با نام کاربری خود وارد شوید یا ثبت نام کنید ] توضیح:
    تعریف متغیرهای i , s ,n
    دریافت عدد n
    تشکیل حلقه while از i=1 تا زمانی که i * i <= n باشه. ( i شمارنده حلقه است)
    البته به نظرم میتونید به جای n ـ، n/2 هم قرار دهید.
    s=i*i
    در هر مرحله بررسی میشه که آیا s با عدد ورودی مساوی هست یا نه
    اگر مساوی بود یعنی مربع کامل است و گرنه میره مرحله بعد؛ مگر اینکه i * i >= n باشه.

    [ برای مشاهده لینک ، با نام کاربری خود وارد شوید یا ثبت نام کنید ]
    Last edited by hamed29; 19-12-2014 at 22:40.

  3. #3
    کاربر فعال انجمن گنو لینوکس V i r u s e r's Avatar
    تاريخ عضويت
    Jan 2008
    محل سكونت
    bin/
    پست ها
    2,086

    پيش فرض

    الگوریتم 1
    میتونید اول جذر رو به دست بیارید و بعد ببینید آیا مجذور یک عدد طبیعی هست یا نه.
    مثلاً عدد 36 میشه 6، که یک عدد طبیعی هست.
    ولی اگه از 37 جذر بگیریم، جواب اعشاری میشه؛ پس 37 مربع کامل نیست.

    برای بررسی طبیعی بودن عدد از مقایسه آن با براکت (جزءصحیح) استفاده میکنیم.
    اگر جزء صحیح یک عدد با خودش برابر باشه، اون عدد طبیعی هست.دستور جزء صحصیح : floor

    مثلاً اگه 5.5 رو با جزء صحیحش مقایسه کنیم، با هم برابر نیستن. چون جزء صحیحش میشه 5 !
    یعنی: [5.5] ≠ 5.5



    الگوریتم 2
    اما روش بالا مثل چرخوندن لقمه دور سر هست. بنابر این شما فایل txt زیر رو دانلود کنید.
    برنامه به زبان پاسکال هست اما الگوریتمش فرق نمیکنه. پس شما همین رو به C++ تغییر بدید.
    میخواستم اینجا کپی کنم متنش به هم میریخت!

    [ برای مشاهده لینک ، با نام کاربری خود وارد شوید یا ثبت نام کنید ] توضیح:
    تعریف متغیرهای i , s ,n
    دریافت عدد n
    تشکیل حلقه while از i=1 تا زمانی که i * i <= n باشه. ( i شمارنده حلقه است)
    البته به نظرم میتونید به جای n ـ، n/2 هم قرار دهید.
    s=i*i
    در هر مرحله بررسی میشه که آیا s با عدد ورودی مساوی هست یا نه
    اگر مساوی بود یعنی مربع کامل است و گرنه میره مرحله بعد؛ مگر اینکه i * i >= n باشه.

    [ برای مشاهده لینک ، با نام کاربری خود وارد شوید یا ثبت نام کنید ]
    الگوریتم اول درسته. میشه از تابع sqrt استفاده کرد و بررسی کرد که جواب عدد طبیعی هست یا نه. برای این کار میتونید از تابع floor استفاده کنید یا عدد حاصل رو تبدیل به int کنید و دوباره به double برگردونید
    الگوریتم دوم هم به قدری نا کارامد و کنده که میشه گفت کاملا اشتباهه.

  4. این کاربر از V i r u s e r بخاطر این مطلب مفید تشکر کرده است


  5. #4
    داره خودمونی میشه
    تاريخ عضويت
    Dec 2014
    پست ها
    45

    پيش فرض

    salam bazam mamnun

Thread Information

Users Browsing this Thread

هم اکنون 1 کاربر در حال مشاهده این تاپیک میباشد. (0 کاربر عضو شده و 1 مهمان)

User Tag List

قوانين ايجاد تاپيک در انجمن

  • شما نمی توانید تاپیک ایحاد کنید
  • شما نمی توانید پاسخی ارسال کنید
  • شما نمی توانید فایل پیوست کنید
  • شما نمی توانید پاسخ خود را ویرایش کنید
  •