مشاهده نسخه کامل
: درخواست راهنمایی از دوستان در مورد محاسبه فاکتوریل
دوستان خوب به نظر شما چطور میشه برنامه ای نوشت که فاکتوریل یک عدد از 100 تا 1000 رو بگیره؟
منتظر نظراتتون هستم ...
soda_india
19-01-2008, 18:50
salam dar c mikhai ya ++c
soda_india
19-01-2008, 19:11
#include<iostream.h>
using namespace std;
long long factorial (long a)
{
if (a>1)
return ((long long)a* factorial (a-1));
else
return (long(1));
}
int main()
{
long a;
cout<<"Enter a number:";
cin>>a;
cout<<a<<"!"<< " = "<< factorial (a)<<endl;
return 0;
}
bad_boy_2007
19-01-2008, 22:43
دوستان خوب به نظر شما چطور میشه برنامه ای نوشت که فاکتوریل یک عدد از 100 تا 1000 رو بگیره؟
منتظر نظراتتون هستم ...
فاکتوریل 100 تا 1000 :19::19::19::19::19: مطمئنی دیگه نه ؟ عدد 50 فاکتوریل یه چیزی حدود 64 تا صفر داره ، 100 فاکتوریل 157 تا صفر داره و . . . 1000 فاکتوریل حدود 2500 تا صفر !!!
اگر که قصد انجام این محاسبات رو داری بیخود زحمت نکش که با متغییرهای خود C کار کنی باید محاسباتت رو شبیه سازی کنی که یکم دردسر داره !!! الگوریتمهای شبه سازی جمع و ضرب رو پارسال به عنوان پروژه میان ترم نوشته بودم اگه گیرم آمد واست میزارشون
h_zaman06
19-01-2008, 23:26
این کار که روی کاغذ فکر نکنم زیاد سخت باشه !!!
فکر کنم توی ++c این طوری باشه
یه حلقه میدیم که از یک شروع بشه و تا اون عددی که گرفته یکی یکی بره جلو ... خوب توی حلقه هم یک متغییر برابر همین شمارنده حلقه میدیم ضرب در خود متغییر در این صورت فاکتوریلش بدست میاد
cin>>n
s=1
for (i=1 ; i<=n ; i++){m
s=s*i
{
cout<<s
bad_boy_2007
19-01-2008, 23:40
این کار که روی کاغذ فکر نکنم زیاد سخت باشه !!!
فکر کنم توی ++c این طوری باشه
یه حلقه میدیم که از یک شروع بشه و تا اون عددی که گرفته یکی یکی بره جلو ... خوب توی حلقه هم یک متغییر برابر همین شمارنده حلقه میدیم ضرب در خود متغییر در این صورت فاکتوریلش بدست میاد
cin>>n
s=1
for (i=1 ; i<=n ; i++){m
s=s*i
{
cout<<s
فکر میکنم شما صورت سوال رو کاملا متوجه نشدید :46:
فاکتوریل 100 تا 1000 رقم !!!
متغییر های C ضرفیت پذیرش 2500 رقم را برای محاسبه 1000 فاکتوریل ندارن مثلا نوع Float تنها میتونه 38 رقم داده رو ذخیره کنه که در مقابل 2500 رقم بسیار کوچیک محسوب میشه یا نوع Long فقط 2اعداد تا به توان 64 رو میتونه ذخیره کنه که یک چیزی حدود 19 رقم با معنا است و . . .
شما باید یه کلاس Huge (به صورت Dynamic) براش بنویسی و عملگر ضرب رو OverLoad کنی (شایدم بتونی توی اینترنت با سرچ پیدا کنی همچین کلاسی)
بعد میتونی با نوشتن همین الگوریتم فاکتوریل, به راحتی 1000 فاکتوریل رو در عرض کمتر از 1 میلی ثانیه حساب کنی. :D
h_zaman06
20-01-2008, 12:01
آهان ... شرمنده ... پا جای بزرگوون گذاشتم ... :)
bad_boy_2007
20-01-2008, 16:02
راستی میتونی از فرمول استرلینگ هم استفاده کنی ولی باز هم شبه سازی رو باید برای محاسباتت انجام بدی !!!
ولی برای n های بزرگ تقریب خوبی میزنه :
sqrt(2*pi*n) * ((n/e)^n)
که در این فرمول n عددی هست که میخوای فاکتوریلش رو حساب کنی
عزیزان ممنونم از همتون ، من خودم یه روش پیدا کردم که مبتنی بر فرمولیه که یکی از دوستان در انجمن سایت سازه نوشته شده ، فاکتوریل اعداد خیلی بزرگ تر از این حرف ها رو هم حساب میکنه
عزیزان ممنونم از همتون ،راهنمایی های خیلی خوبی کردید ولی من خودم یه روش بهتر پیدا کردم که مبتنی بر فرمولیه که یکی از دوستان در انجمن سایت سازه نوشته ،
فاکتوریل اعداد خیلی بزرگ تر از این حرف ها رو هم حساب میکنه:31:
اگر کسی لازمش داره برام Pm بزاره و یا منتظر باشید تا انشا الله بعدا بزارم تو سایتم . لینکش رو بدم
sherlockholmz
26-01-2008, 10:30
عزیزان ممنونم از همتون ،راهنمایی های خیلی خوبی کردید ولی من خودم یه روش بهتر پیدا کردم که مبتنی بر فرمولیه که یکی از دوستان در انجمن سایت سازه نوشته ،
فاکتوریل اعداد خیلی بزرگ تر از این حرف ها رو هم حساب میکنه:31:
اگر کسی لازمش داره برام Pm بزاره و یا منتظر باشید تا انشا الله بعدا بزارم تو سایتم . لینکش رو بدم
سلام،
ممنون مي شوم كه روش كار را توضيح بدي و يا برنامه را درج كني
برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید
log10 یعنی لگاریتم بر مبنای 10
[s] یعنی جزء صحیح s
n عدد مورد محاسبه است .
دوستان لطفا کپی رایت رو حفظ کنن . ممنونم:20:
فایل شامل : سورس به زبان C و کامپایل شده و چند خروجی
برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید
reza_senior
28-01-2008, 16:50
سلام دوستان
فقط دو روز وقت دارم که برنامه فاکتوریل در ++c را تحویل استادمون بدم .
آگه لطف کنید کمکم کنید و برام بذارید ممنون میشم .
من یه برنامه پیدا کرده بودم ولی این برنامه فقط فاکتوریل تعداد محدودی از اعداد رو محاسبه میکنه .
من یه برنامه میخوام که هر عددی بهش بدیم فاکتوریل رو حساب کنه .
سلام دوستان
فقط دو روز وقت دارم که برنامه فاکتوریل در ++c را تحویل استادمون بدم .
آگه لطف کنید کمکم کنید و برام بذارید ممنون میشم .
من یه برنامه پیدا کرده بودم ولی این برنامه فقط فاکتوریل تعداد محدودی از اعداد رو محاسبه میکنه .
من یه برنامه میخوام که هر عددی بهش بدیم فاکتوریل رو حساب کنه .
دوست خوب این برنامه همینی هست که دنبالشی منتها به C هست نه C++.
شما فقط stdio.h رو تبدیل به iostream.h کن و همه scanf ها رو به شکل cin و همه printf ها رو به شکل cout در بیار
یا یکی از دوستان زحمتش رو بکشه . تبدیل میشه به ++C.:31:
vBulletin , Copyright ©2000-2025, Jelsoft Enterprises Ltd.