محاسبه فاکتوریل در پایتون — به زبان ساده + کد برنامه

۵۹۵۰ بازدید
آخرین به‌روزرسانی: ۱۷ خرداد ۱۴۰۲
زمان مطالعه: ۷ دقیقه
محاسبه فاکتوریل در پایتون — به زبان ساده + کد برنامه

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

فاکتوریل چیست؟

در ریاضیات، فاکتوریل یک عدد یعنی آن عدد در تمام اعداد طبیعی پیش از خود ضرب شود. فاکتوریل به صورت نمادین، با علامت «!» نشان داده می‌شود. به این ترتیب، n فاکتوریل حاصل ضرب n عدد طبیعی اولیه است و به صورت !n نمایش داده می‌شود. به عنوان مثال، !5 (فاکتوریل ۵) یعنی اعداد یک تا ۵ همگی باید در یکدیگر ضرب شوند.

در صورت محاسبه ضرب اعداد ۱ تا ۵، مقدار پنج فاکتوریل که ۱۲۰ است به دست خواهد آمد. البته باید توجه داشت که محاسبه فاکتوریل تنها برای اعداد مثبت امکان‌پذیر است و نمی‌توان آن را برای اعداد منفی به کار برد. علاوه بر این، به عنوان یک قانون کلی، همیشه فاکتوریل عدد صفر برابر یک است. به منظور درک بهتر مفاهیم پایه فاکتوریل، می‌توان از تصویر زیر کمک گرفت:

نحوه محاسبه فاکتوریل در پایتون

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

برنامه محاسبه فاکتوریل در پایتون

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

الگوریتم محاسبه فاکتوریل در پایتون

در این بخش از مقاله «محاسبه فاکتوریل در پایتون»، کارکرد الگوریتم فاکتوریل به صورت مرحله به مرحله فهرست شده است:

  1. در ابتدا باید یک عدد صحیح مثبت از کاربر دریافت و در متغیر n قرار داده شود.
  2. عدد یک در متغیر factorial قرار داده شود.
  3. لازم است یک شمارنده، به منظور شمارش ۱ تا n استفاده شود (این شمارنده برای افزایش تعداد ورودی‌های داده شده کاربرد دارد).
  4. حال باید مقدار متغیر factorial در متغیر i ضرب شود و حاصل آن در factorial قرار بگیرد.
  5. در صورتی که i از n کوچک‌تر باشد، باید مجدداً به گام 4 بازگشت.
  6. چاپ خروجی یا همان فاکتوریل محاسبه‌شده عدد n
  7. خاتمه اجرای کدها

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

انواع روش‌های محاسبه فاکتوریل در پایتون

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

این روش‌ها سه مورد زیر را شامل می‌شوند:

  • استفاده از حلقه for
  • استفاده از تابع بازگشتی
  • استفاده از تابع factorial کتابخانه‌ math

روش اول: محاسبه فاکتوریل در پایتون با حلقه for

در این رویکرد تکرارشونده (Iterative)، با استفاده از الگوریتم ارائه شده در بخش قبلی این مقاله، ابتدا یک عدد صحیح از کاربر دریافت می‌شود و در ادامه لازم است متغیری با نام factorial تعریف و به آن مقدار یک اختصاص داده شود.

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

1number = int(input("please Enter integer number: "))
2factorial = 1

پس از نوشتن کدهای فوق، یک حلقه‌ی تکرار for لازم است تا با استفاده از آن از 1 تا number پیمایش انجام شود. باید توجه کرد که تمام اعداد کوچک‌تر مساوی number درون این حلقه شمارش از یک تا خود آن عدد همگی در هم ضرب شده‌اند و در نهایت، حاصل در متغیر factorial قرار می‌گیرد. نحوه نوشتن حلقه تکرار for در ادامه آمده است:

1...
2for i in range(1, number+1):
3    factorial = factorial * i

مشابه مراحل ذکر شده در بخش کارکرد الگوریتم، اکنون باید مقدار محاسبه شده فاکتوریل موجود در متغیر factorial چاپ شود. کدهای زیر به منظور چاپ فاکتوریل عدد دریافت شده از کاربر استفاده می‌شوند:

12print("The factorial of {} is: {}".format(number, factorial))

به منظور درک بهتر و اجتناب از هر گونه سردرگمی و ابهام، قطعه کد مربوط به محاسبه فاکتوریل با حلقه for در پایتون به صورت یک جا در ادامه آمده است:

1number = int(input("please Enter integer number: "))
2factorial = 1
3for i in range(1, number+1):
4    factorial = factorial * i
5print("The factorial of {} is: {}".format(number, factorial))

حال برای تست کدهای فوق، فاکتوریل عدد ۱۴ به عنوان مثال در ادامه محسابه شده است:

1please Enter integer number: 14
2
3
4The factorial of 14 is: 87178291200

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

روش دوم: محاسبه فاکتوریل در پایتون با تابع بازگشتی

علاوه بر حلقه تکرار، می‌توان از تابع بازگشتی نیز برای محاسبه فاکتوریل در پایتون استفاده کرد. منظور از توابع بازگشتی، تابع‌هایی است که برای اجرای کامل به تعداد مورد نیاز خودشان را به طور پی در پی فراخوانی می کنند. این فراخوانی‌های پی در پی تا زمانی که برنامه به «پایه تابع» برسد ادامه خواهند داشت. در بیشتر مواقع، از توابع بازگشتی برای محاسبه دنباله‌های ریاضی یا حل مسائل ریاضی استفاده می‌شود. چرا که معمولاً یک فرمول تعریف شده وجود دارد که برای محاسبه پاسخ مسئله مورد استفاده قرار می‌گیرد.

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

1def factorial(n):
2    if n == 0:
3        return 1

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

1def factorial(n):
2    if n == 0:
3        return 1
4    else:
5        return n * factorial(n-1)

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

1...
2number = int(input("please Enter integer number: "))
3result = factorial(number)
4print("The factorial of {} is: {}".format(number, result))

برنامه کامل محاسبه فاکتوریل در پایتون با استفاده از تابع بازگشتی به شکل زیر قابل پیاده‌سازی است:

1def factorial(n):
2    if n == 0:
3        return 1
4    else:
5        return n * factorial(n-1)
6number = int(input("please Enter integer number: "))
7result = factorial(number)
8print("The factorial of {} is: {}".format(number, result))

برای مثال، خروجی محاسبه فاکتوریل در پایتون با استفاده از تابع بازگشتی برای عدد ۵ به صورت زیر است:

1please Enter integer number: 5
2
3
4The factorial of 5 is: 120

روش سوم : محاسبه فاکتوریل در پایتون با تابع factorial کتابخانه‌ math

می‌توان محاسبه فاکتوریل در پایتون را با به کارگیری ماژول ریاضی پایتون با نام Math انجام داد. کتابخانه ریاضیات پایتون حاوی طیف وسیعی از متُدهای کاربردی برای اجرای توابع ریاضی است. به عنوان مثال، امکان استفاده از کتابخانه Math برای تولید اعداد تصادفی وجود دارد.

لازم به ذکر است که پیش از استفاده از ماژول Math پایتون، باید آن را در پروژه اضافه‌ (Import) کرد. پس از آن، می‌توان با کمک تابع ()factorial از کتابخانه ریاضی پایتون، مقدار فاکتوریل عدد دریافتی را محاسبه کرد. برای محاسبه فاکتوریل در پایتون با کمک کتابخانه math، از کدهای زیر استفاده می‌شود:

1import math
2number = int(input("please Enter integer number: "))
3result = math.factorial(number)
4print("The factorial of {} is: {}".format(number, result))

خروجی محاسبه فاکتوریل عدد ۱۰ با استفاده از روش فوق به صورت زیر است:

1
2please Enter integer number: 10
3
4
5The factorial of 10 is: 3628800

در صورتی که در برنامه محاسبه فاکتوریل یک عدد منفی مثل ۱۵-  توسط کاربر وارد شود، خطای زیر نمایش داده خواهد شد:

1please Enter integer number: -15
2
3
4Traceback (most recent call last):
5
6
7File “c:/Users/Faradars/Desktop/Python/factorial.py”, line 21, in <module>
8
9
10result = math.factorial(number)
11
12
13ValueError: factorial() not defined for negative values

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

کدهای بهبود یافته برای جلوگیری از بروز خطا در صورت منفی بودن عدد ورودی

کدهای بهبود یافته مربوط به هر یک از روش‌های محاسبه فاکتوریل در پایتون در این بخش ارائه شده‌اند. در تمام این کدها پیش از محاسبه فاکتوریل در پایتون ، با استفاده از دستور شرطی if بررسی می‌شود که عدد وارد شده توسط کاربر منفی نباشد.

کدهای بهبود یافته محاسبه فاکتوریل در پایتون با استفاده از حلقه for به صورت زیر است:

1number = int(input("please Enter integer number: "))
2if number < 0:
3    print("Sorry, factorial does not exist for negative numbers")
4else:
5    factorial = 1
6    for i in range(1, number+1):
7        factorial = factorial * i
8print("The factorial of {} is: {}".format(number, factorial))

کدهای بهبود یافته محاسبه فاکتوریل در پایتون با استفاده از تابع بازگشتی نیز در ادامه آمده است:

1def factorial(n):
2if n == 0:
3return 1
4else:
5return n * factorial(n-1)
6number = int(input("please Enter integer number: "))
7if number < 0:
8print("Sorry, factorial does not exist for negative numbers")
9else:
10result = factorial(number)
11print("The factorial of {} is: {}".format(number, result))

در نهایت، کدهای بهبود یافته محاسبه فاکتوریل در پایتون با استفاده از کتابخانه math نیز به صورت زیر هستند:

1import math
2number = int(input("please Enter integer number: "))
3if number < 0:
4print("Sorry, factorial does not exist for negative numbers")
5else:
6result = math.factorial(number)
7print("The factorial of {} is: {}".format(number, result))

خروجی کدهای بهبود یافته محاسبه فاکتوریل در پایتون

خروجی هر سه قطعه کد فوق برای عدد ۱۵- به صورت زیر است:

1lease Enter integer number: -15
2
3
4Sorry, factorial does not exist for negative numbers

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

جمع‌بندی

در این مقاله به نحوه محاسبه فاکتوریل در پایتون با استفاده از سه رویکرد مختلف پرداخته شد. این سه رویکرد شامل محاسبه فاکتوریل در پایتون با حلقه for، محاسبه فاکتوریل در پایتون به روش بازگشتی و در نهایت محاسبه فاکتوریل در پایتون با استفاده از تابع Factorial در کتابخانه Math پایتون است.

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

بر اساس رای ۱۶ نفر
آیا این مطلب برای شما مفید بود؟
اگر بازخوردی درباره این مطلب دارید یا پرسشی دارید که بدون پاسخ مانده است، آن را از طریق بخش نظرات مطرح کنید.
منابع:
Career KarmaTutorials PointGeeks For Geeks
نظر شما چیست؟

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *