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

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




صفحه 2 از 2 اولاول 12
نمايش نتايج 11 به 13 از 13

نام تاپيک: يك مشكل

  1. #11
    آخر فروم باز hamidreza_buddy's Avatar
    تاريخ عضويت
    Sep 2004
    محل سكونت
    شریف
    پست ها
    1,167

    پيش فرض

    من خودم ميدونستم كه ورودي متد Returner بايد توان باشه ولي بايد در اينجا براي بهتر شدن برنامه پايه ي توان ارسال بشه
    اگه برنامه رو یه بار تریس می کردی متوجه می شدی بهتره یا نه!


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

    کد:
    برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید
    البته به نظر من باید یه تابع توان رو توی کلاس Number ایجاد کنی. چون توان یه «عمل» هست. وگرنه باید برای جمع و ضرب و ... هم هر کدوم یه کلاس بسازی! هنوز یه کم «مفهوم» کلاس ها رو خوب متوجه نشدی.
    در ضمن اگه می خای کلاس Number درست کنی، اون رو جامع درست کن (با جمع و تفریق و ...) که بتونی کلاً به جای int از اون استفاده کنی.

  2. #12
    پروفشنال mahdi7s's Avatar
    تاريخ عضويت
    Sep 2007
    محل سكونت
    هر جایی می تونه باشه
    پست ها
    757

    پيش فرض

    كار اين تابع بازگشتي(ReturnerRec ) كه شما ايجاد كردين چيه ؟

  3. #13
    آخر فروم باز hamidreza_buddy's Avatar
    تاريخ عضويت
    Sep 2004
    محل سكونت
    شریف
    پست ها
    1,167

    پيش فرض

    معمولاً اگه یه الگوریتم رو به صورت بازگشتی بنویسی، برای شروع اون الگوریتم، باید اون رو با یه پارامتر خاصی صدا بزنی. مثلاً تو مثال بالا میشه تابع Returner رو به صورت
    کد:
    برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید
    تعریف کنی (چون قبلاً تو سازنده کلاس، مقدار power رو دادی و ذخیره کردی و نیازی نیست دوباره یه مقدار بفرستی).

    در نتیجه یه تابع عمومی با نقش «واسط» می گذاریم تا کسی که می خواد از اون کلاس استفاده کنه خیلی درگیر جزییات نشه.
    و توابع دیگر رو به صورت خصوصی تعریف می کنیم. این توابع خصوصی نقش انجام دهنده کار رو دارن و بهتره به دلیل اینکه کمی جزئی کار می کنن با اون ها بوسیله تابع واسطه در ارتباط باشیم.

    در اینجا ReturnerRex یک تابع بازگشتی هست که به صورت بازگشتی مقدار مورد نظر رو حساب می کنه. داریم:
    کد:
    برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید
    یعنی اینکه n^p برابر n * n^p-1 هست.

    البته بهتره که برا محاسبه توان از حلقه ساده استفاده کنی تا overhead فراخوانی پی در پی تابع رو نداشته باشی.

  4. این کاربر از hamidreza_buddy بخاطر این مطلب مفید تشکر کرده است


صفحه 2 از 2 اولاول 12

Thread Information

Users Browsing this Thread

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

User Tag List

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

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