زمان کنونی: ۲۵ دى ۱۴۰۳, ۰۶:۳۰ ق.ظ مهمان گرامی به انجمن مانشت خوش آمدید. برای استفاده از تمامی امکانات انجمن می‌توانید عضو شوید.
گزینه‌های شما (ورودثبت نام)

مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

ارسال:
  

mahdi200hell پرسیده:

Lightbulb مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

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

دوستان اگر تستی به نظرشون جالب و نکته دار اومد به من پیغام خصوصی بدن تا بتونیم از همین تستا از خودمون آزمون بگیریم.

برای بقیه دروس هم تاپیک درس میکنم.

قوانین:
۱-به همدیگه و نظرات همدیگه احترام بذاریم.
۲-پست الکی نذارین که تاپیک شلوغ بشه.
۳- حجم مطالعه شما، شیوه مطالعه شما و زمان بندیتون و ... به هیچ کسه دیگه مربوط نمیشه پس خواهشن اینجا مطرح نکنید.ما اینجا فقط رفع اشکال میکنیم.
۴- در ادامه قانون بالا سوالات غیر درسی نپرسید .
۵-از پرسیدن منابع مربوط به درس در این تاپیک خودداری کنید(خودش تاپیک جدا داره).
۶-از نقل قول های پی درپی و نقل قول متن های طولانی پرهیز کنید
۷- بجای تشکر و منم هستم تعریف و تمجید ها فقط سپاس بزنین
۸- هرسوالی که داشتید در تاپیک زیر مطرح کنید :

مهمان عزیز شما قادر به مشاهده پیوندهای انجمن مانشت نمی‌باشید. جهت مشاهده پیوندها ثبت نام کنید.


در پایان باید عرض کنم که اگر دوستی چیزی به ذهنش رسید برای ارتقا و بهبود کار به من پیغام بده تا من تاثیر بدم.و باید بگم که اینکار کار مشکلی هست و فقط باید با همدیگه همکاری کنیم.

با تشکر از شما دوستان

شنبه ۷ تیر تا شنبه ۱۴ تیر:


الگوریتم (تجزیه و تحلیل)

شنبه ۱۴ تیر تا شنبه ۲۱ تیر:

صف و پشته

شنبه ۲۱ تیر تا شنبه ۲۸ تیر:

لیست پیوندی

شنبه ۲۸ تیر تا شنبه ۳ مرداد:

درخت

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

۱
ارسال:
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

خب ببین یه راست بریم تا وقتی که مجموع رو حساب کنیم.مجموع به صورت یه کسره درسته؟وقتی مقدار هر سطح رو حساب کنیم صورت کسر همیشه n میشه که تو این مشکل نیست خب ؟
حالا میمونه مخرج:توی سطح اول مخرج همه ی کسرها اینه:logn22 حالا مقدار اینو چجوری محاسبه میکنیم؟
logn22: kjklogn22=logn2log22=logn21

حالا توی سطح دوم مخرج همه کسر ها اینه:logn42 حالا مقدار اینو چجوری محاسبه میکنیم؟
logn42=logn2log42=logn22

و برای بقیه سطح ها هم ادامه داره و نهایتا مجموع:
n(1lgn1lgn11lgn2...1)=θ(n.lglgn)

ارسال:
  

shayesteb پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۹ مرداد ۱۳۹۳ ۰۸:۱۹ ب.ظ)miladcr7 نوشته شده توسط:  خب ببین یه راست بریم تا وقتی که مجموع رو حساب کنیم.مجموع به صورت یه کسره درسته؟وقتی مقدار هر سطح رو حساب کنیم صورت کسر همیشه n میشه که تو این مشکل نیست خب ؟
حالا میمونه مخرج:توی سطح اول مخرج همه ی کسرها اینه:logn22 حالا مقدار اینو چجوری محاسبه میکنیم؟
logn22: kjklogn22=logn2log22=logn21

حالا توی سطح دوم مخرج همه کسر ها اینه:logn42 حالا مقدار اینو چجوری محاسبه میکنیم؟
logn42=logn2log42=logn22

و برای بقیه سطح ها هم ادامه داره و نهایتا مجموع:
n(1lgn1lgn11lgn2...1)=θ(n.lglgn)

جواب این طوری هست:

nlogn <--- سطر اول درخت

n5log(n5) n5log(n5) <---سطر دوم درخت

n52log(n52) سطر دوم درخت که ۴ تا از اینا هست

حالا میرسیم به نوشتم فرمولهای هر سطر :

نکتش اینه که n5log(n5)=n(lognlog5)=nlogn1

توجه کنید که لگاریتم در مبنای ۵ هست به خاطر همینه که لگاریتم ۵ برابر یک میشه

همونطور که میبینید دقیقا فرمولش با اون مثالی که توی کتاب حلش کرده برابره و جوابشون یکی میشه Smile
یافتن تمامی ارسال‌های این کاربر

ارسال:
  

shayesteb پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۹ مرداد ۱۳۹۳ ۰۹:۵۱ ب.ظ)shayesteb نوشته شده توسط:  
(29 مرداد ۱۳۹۳ ۰۸:۱۹ ب.ظ)miladcr7 نوشته شده توسط:  خب ببین یه راست بریم تا وقتی که مجموع رو حساب کنیم.مجموع به صورت یه کسره درسته؟وقتی مقدار هر سطح رو حساب کنیم صورت کسر همیشه n میشه که تو این مشکل نیست خب ؟
حالا میمونه مخرج:توی سطح اول مخرج همه ی کسرها اینه:logn22 حالا مقدار اینو چجوری محاسبه میکنیم؟
logn22: kjklogn22=logn2log22=logn21

حالا توی سطح دوم مخرج همه کسر ها اینه:logn42 حالا مقدار اینو چجوری محاسبه میکنیم؟
logn42=logn2log42=logn22

و برای بقیه سطح ها هم ادامه داره و نهایتا مجموع:
n(1lgn1lgn11lgn2...1)=θ(n.lglgn)

جواب این طوری هست:

nlogn <--- سطر اول درخت

n5log(n5) n5log(n5) <---سطر دوم درخت

n52log(n52) سطر دوم درخت که ۴ تا از اینا هست

حالا میرسیم به نوشتم فرمولهای هر سطر :

نکتش اینه که n5log(n5)=n(lognlog5)=nlogn1

توجه کنید که لگاریتم در مبنای ۵ هست به خاطر همینه که لگاریتم ۵ برابر یک میشه

همونطور که میبینید دقیقا فرمولش با اون مثالی که توی کتاب حلش کرده برابره و جوابشون یکی میشه Smile

نه اشتباه نکنید لگاریتم در مبنای ۲ نیست در مبنای ۵ هست. چرا؟

چونکه در صورت سوال داریم T(n5) پس در هر سطر (همونطور که در بالا میبینید) توانی از ۵/n جایگزین n میشود. Smile
یافتن تمامی ارسال‌های این کاربر

۰
ارسال:
  

Pakniat پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

به نظرتون کدامیک از روابط زیر درست است :

o(f(n))O(f(n))(f(n))

o(f(n))!=O(f(n))(f(n))

ارسال:
  

mahdi200hell پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۱۷ تیر ۱۳۹۳ ۰۳:۰۵ ب.ظ)Pakniat نوشته شده توسط:  به نظرتون کدامیک از روابط زیر درست است :

o(f(n))O(f(n))(f(n))

o(f(n))!=O(f(n))(f(n))

له نظره من دومی درسته.
چون براساس تعریف big O: از یک نقطه ای به بعد بزرگتر از تابع میشه در صورتیکه small o مطلاقا از تابع بزرگتره و نقطه اشتراک نداره.پس
big O زیر مجموعه small o حساب میشه.حالا شما اگه تتای تابع رو که از big O کوچکتره رو ازش کم کنید حتما از small o کمتر میشه.پس نتیجه میگیریم حاصل تفریق زیر مجموعه small o هستش نه برعکس.
که همین باعث میشه مورد دوم درست[/size] باشه
یافتن تمامی ارسال‌های این کاربر

ارسال:
  

Pakniat پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۱۷ تیر ۱۳۹۳ ۰۵:۴۲ ب.ظ)mahdi200hell نوشته شده توسط:  له نظره من دومی درسته.
چون براساس تعریف big O: از یک نقطه ای به بعد بزرگتر از تابع میشه در صورتیکه small o مطلاقا از تابع بزرگتره و نقطه اشتراک نداره.پس
big O زیر مجموعه small o حساب میشه.حالا شما اگه تتای تابع رو که از big O کوچکتره رو ازش کم کنید حتما از small o کمتر میشه.پس نتیجه میگیریم حاصل تفریق زیر مجموعه small o هستش نه برعکس.
که همین باعث میشه مورد دوم درست[/size] باشه
اگر فرض بشه f(n)=n;g(n)=nifn=2k,1ifn=2k1 در این حالت مورد دوم رو برای n های زوج چک کنید
یافتن تمامی ارسال‌های این کاربر

ارسال:
  

mahdi200hell پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

If ( f(n) == sqrt(x) ) then

Y=x is O(f(n)) and

Y=(x^2)+2 is o(f(n)) and

Y=sqrt(x-2) is Ɵ(f(n))


مهمان عزیز شما قادر به مشاهده پیوندهای انجمن مانشت نمی‌باشید. جهت مشاهده پیوندها ثبت نام کنید.
اینم لینک رسم نمودار این مثال نقض

میبینید که تساوی اول هیچ وقت واسه این مثال برقرار نمیشه
اینجور سوالارو فقط باید با تعریفش حل کرد
یافتن تمامی ارسال‌های این کاربر

ارسال:
  

Pakniat پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۱۷ تیر ۱۳۹۳ ۰۷:۲۲ ب.ظ)mahdi200hell نوشته شده توسط:  If ( f(n) == sqrt(x) ) then

Y=x is O(f(n)) and

Y=(x^2)+2 is o(f(n)) and

Y=sqrt(x-2) is Ɵ(f(n))


مهمان عزیز شما قادر به مشاهده پیوندهای انجمن مانشت نمی‌باشید. جهت مشاهده پیوندها ثبت نام کنید.
اینم لینک رسم نمودار این مثال نقض

میبینید که تساوی اول هیچ وقت واسه این مثال برقرار نمیشه
اینجور سوالارو فقط باید با تعریفش حل کرد
x21o(x)
در ضمن Y شما تابع نیست ؛ به ازای هر x چند نگاشت مختلف در صفحه دارد
یافتن تمامی ارسال‌های این کاربر

ارسال: #۱۰
  

hamedfayez پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۱۷ تیر ۱۳۹۳ ۰۵:۴۲ ب.ظ)mahdi200hell نوشته شده توسط:  
(17 تیر ۱۳۹۳ ۰۳:۰۵ ب.ظ)Pakniat نوشته شده توسط:  به نظرتون کدامیک از روابط زیر درست است :

o(f(n))O(f(n))(f(n))

o(f(n))!=O(f(n))(f(n))

له نظره من دومی درسته.
چون براساس تعریف big O: از یک نقطه ای به بعد بزرگتر از تابع میشه در صورتیکه small o مطلاقا از تابع بزرگتره و نقطه اشتراک نداره.پس
big O زیر مجموعه small o حساب میشه.حالا شما اگه تتای تابع رو که از big O کوچکتره رو ازش کم کنید حتما از small o کمتر میشه.پس نتیجه میگیریم حاصل تفریق زیر مجموعه small o هستش نه برعکس.
که همین باعث میشه مورد دوم درست[/size] باشه
دارید برعکس میگیدا ! یعنی little O زیر مجموعه ی Big O میشه !! به عبارتی این رابطه بینشون برقراره !
o(n)O(n)
طبق تعریف litte o شامل مجموعه از توابع میشه که ازش کمتر باشن ( حد بالاشون little o باشه ) ولی تعریف Big o میشه کمتر یا مساوی مثلا O(x^2) رو و o(x^2) می بینید که تابع x^2+1 عضو little o نخواهد بود در صورتی که عضو big o هستش و همینطور عضو تتای x^2 !
یافتن تمامی ارسال‌های این کاربر

۰
ارسال: #۱۱
  

A V A پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

بعضی وقتها توو یه سری نکات مسخره انقدر گیر میکنیم که....
و الان من توو تفاوت این دوتا موندم
به این فرمول رسیدم o(f)O(f)Omega(f) و گفته شده دلیلش اینه که توو سمت راستی توابعی هست که توو سمت چپی نیس. خب این که تعریفه این یکیه

ارسال: #۱۲
  

nlp@2015 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۶ تیر ۱۳۹۳ ۰۲:۰۳ ب.ظ)Ava.arshad94 نوشته شده توسط:  بعضی وقتها توو یه سری نکات مسخره انقدر گیر میکنیم که....
و الان من توو تفاوت این دوتا موندم
به این فرمول رسیدم o(f)O(f)Omega(f) و گفته شده دلیلش اینه که توو سمت راستی توابعی هست که توو سمت چپی نیس. خب این که تعریفه این یکیه

این چیزی ک شما میگید درستش اینه o(f)O(f)θ(f) و بعد هم فرق نماد و در این هست ک در مورد اولی ممکنه یک جاهایی هم دو طرف برابر بشن (تابعی ک انتخاب میکنید) ولی در مورد دومی میدانیم ک هیچ وقت مساوی نیستند صرفا زیرمجموعشه امکان مساوی بودن نداره.
یافتن تمامی ارسال‌های این کاربر

ارسال: #۱۳
  

A V A پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۶ تیر ۱۳۹۳ ۰۶:۲۲ ب.ظ)mahnaz.p نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۲:۰۳ ب.ظ)Ava.arshad94 نوشته شده توسط:  بعضی وقتها توو یه سری نکات مسخره انقدر گیر میکنیم که....
و الان من توو تفاوت این دوتا موندم
به این فرمول رسیدم o(f)O(f)Omega(f) و گفته شده دلیلش اینه که توو سمت راستی توابعی هست که توو سمت چپی نیس. خب این که تعریفه این یکیه

این چیزی ک شما میگید درستش اینه o(f)O(f)θ(f) و بعد هم فرق نماد و در این هست ک در مورد اولی ممکنه یک جاهایی هم دو طرف برابر بشن (تابعی ک انتخاب میکنید) ولی در مورد دومی میدانیم ک هیچ وقت مساوی نیستند صرفا زیرمجموعشه امکان مساوی بودن نداره.

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

ارسال: #۱۴
  

nlp@2015 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۶ تیر ۱۳۹۳ ۰۶:۳۱ ب.ظ)Ava.arshad94 نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۲۲ ب.ظ)mahnaz.p نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۲:۰۳ ب.ظ)Ava.arshad94 نوشته شده توسط:  بعضی وقتها توو یه سری نکات مسخره انقدر گیر میکنیم که....
و الان من توو تفاوت این دوتا موندم
به این فرمول رسیدم o(f)O(f)Omega(f) و گفته شده دلیلش اینه که توو سمت راستی توابعی هست که توو سمت چپی نیس. خب این که تعریفه این یکیه

این چیزی ک شما میگید درستش اینه o(f)O(f)θ(f) و بعد هم فرق نماد و در این هست ک در مورد اولی ممکنه یک جاهایی هم دو طرف برابر بشن (تابعی ک انتخاب میکنید) ولی در مورد دومی میدانیم ک هیچ وقت مساوی نیستند صرفا زیرمجموعشه امکان مساوی بودن نداره.

مرسی دوست عزیز
فرموله شما درست اما چیزی که من نوشتم یه فرمول دیگه ستBig Grin و سوالم اینه که نباید اون علامت زیر مجموعه تغییر کنه؟ چون یه فرموله دیگه میگه این دو عبارتی که نوشتم برابرنیستن.پس وقتی برابر نیستن زیر مجموعه باید محض باشه و بدون اون خط کوفتیه زیرش
همین نکات ریز ممکنه بعضی وقتا از زیر دستمون در برن...

آها ببخشید حواسم نبود این فرمولیم ک شما نوشتید درسته و علامت زیر مجموعه مساوی باید باشه چون وقتی امگا رو از O کم میکنیم در واقه همون هم مرتبه ها یعنی همون تتا رو ازش کم میکنه(مرتبه های بالا ک اصلا تو O نیستند !) حالت مساوی هم پیش میاد مثلن f=n بگیرید
یافتن تمامی ارسال‌های این کاربر

ارسال: #۱۵
  

A V A پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۶ تیر ۱۳۹۳ ۰۶:۳۹ ب.ظ)mahnaz.p نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۳۱ ب.ظ)Ava.arshad94 نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۲۲ ب.ظ)mahnaz.p نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۲:۰۳ ب.ظ)Ava.arshad94 نوشته شده توسط:  بعضی وقتها توو یه سری نکات مسخره انقدر گیر میکنیم که....
و الان من توو تفاوت این دوتا موندم
به این فرمول رسیدم o(f)O(f)Omega(f) و گفته شده دلیلش اینه که توو سمت راستی توابعی هست که توو سمت چپی نیس. خب این که تعریفه این یکیه

این چیزی ک شما میگید درستش اینه o(f)O(f)θ(f) و بعد هم فرق نماد و در این هست ک در مورد اولی ممکنه یک جاهایی هم دو طرف برابر بشن (تابعی ک انتخاب میکنید) ولی در مورد دومی میدانیم ک هیچ وقت مساوی نیستند صرفا زیرمجموعشه امکان مساوی بودن نداره.

مرسی دوست عزیز
فرموله شما درست اما چیزی که من نوشتم یه فرمول دیگه ستBig Grin و سوالم اینه که نباید اون علامت زیر مجموعه تغییر کنه؟ چون یه فرموله دیگه میگه این دو عبارتی که نوشتم برابرنیستن.پس وقتی برابر نیستن زیر مجموعه باید محض باشه و بدون اون خط کوفتیه زیرش
همین نکات ریز ممکنه بعضی وقتا از زیر دستمون در برن...

آها ببخشید حواسم نبود این فرمولیم ک شما نوشتید درسته و علامت زیر مجموعه مساوی باید باشه چون وقتی امگا رو از O کم میکنیم در واقه همون هم مرتبه ها یعنی همون تتا رو ازش کم میکنه(مرتبه های بالا ک اصلا تو O نیستند !) حالت مساوی هم پیش میاد مثلن f=n بگیرید

نه.این مثال نقضشه
تابع دو ضابطه ای که برای nهای زوج مقدار n داشته باشه و برای n های فرد مقدار ۱
اینطوری میشه fo(n) چون یه جاهای مساوی n هست و طبق تعریف little o نباید مساوی باشه
اما بااین حال fO(n)Omega(f) درسته
با این مثال نقض باید زیر مجموعه ی محض باشهHuh

این مثال نقض ماله جزوه ی استاد یوسفی هست مال منم نیست Big Grin
یافتن تمامی ارسال‌های این کاربر

ارسال: #۱۶
  

nlp@2015 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۶ تیر ۱۳۹۳ ۰۶:۴۶ ب.ظ)Ava.arshad94 نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۳۹ ب.ظ)mahnaz.p نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۳۱ ب.ظ)Ava.arshad94 نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۲۲ ب.ظ)mahnaz.p نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۲:۰۳ ب.ظ)Ava.arshad94 نوشته شده توسط:  بعضی وقتها توو یه سری نکات مسخره انقدر گیر میکنیم که....
و الان من توو تفاوت این دوتا موندم
به این فرمول رسیدم o(f)O(f)Omega(f) و گفته شده دلیلش اینه که توو سمت راستی توابعی هست که توو سمت چپی نیس. خب این که تعریفه این یکیه

این چیزی ک شما میگید درستش اینه o(f)O(f)θ(f) و بعد هم فرق نماد و در این هست ک در مورد اولی ممکنه یک جاهایی هم دو طرف برابر بشن (تابعی ک انتخاب میکنید) ولی در مورد دومی میدانیم ک هیچ وقت مساوی نیستند صرفا زیرمجموعشه امکان مساوی بودن نداره.

مرسی دوست عزیز
فرموله شما درست اما چیزی که من نوشتم یه فرمول دیگه ستBig Grin و سوالم اینه که نباید اون علامت زیر مجموعه تغییر کنه؟ چون یه فرموله دیگه میگه این دو عبارتی که نوشتم برابرنیستن.پس وقتی برابر نیستن زیر مجموعه باید محض باشه و بدون اون خط کوفتیه زیرش
همین نکات ریز ممکنه بعضی وقتا از زیر دستمون در برن...

آها ببخشید حواسم نبود این فرمولیم ک شما نوشتید درسته و علامت زیر مجموعه مساوی باید باشه چون وقتی امگا رو از O کم میکنیم در واقه همون هم مرتبه ها یعنی همون تتا رو ازش کم میکنه(مرتبه های بالا ک اصلا تو O نیستند !) حالت مساوی هم پیش میاد مثلن f=n بگیرید

نه.این مثال نقضشه
تابع دو ضابطه ای که برای nهای زوج مقدار n داشته باشه و برای n های فرد مقدار ۱
اینطوری میشه fo(n) چون یه جاهای مساوی n هست و طبق تعریف little o نباید مساوی باشه
اما بااین حال fO(n)Omega(f) درسته
با این مثال نقض باید زیر مجموعه ی محض باشهHuh

این مثال نقض ماله جزوه ی استاد یوسفی هست مال منم نیست Big Grin

درسته این مثال نقضشه منم نگفتم همه جا صادقه واسه همینم نماد زیرمجموعه مساوی میزاریم نه نماد مساوی خالی!یعنی بسته به تابعی ک داریم ممکنه مساوی شه یا زیر مجموعش باشه و نه مساویRolleyes
یافتن تمامی ارسال‌های این کاربر

ارسال: #۱۷
  

A V A پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۶ تیر ۱۳۹۳ ۰۷:۱۶ ب.ظ)mahnaz.p نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۴۶ ب.ظ)Ava.arshad94 نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۳۹ ب.ظ)mahnaz.p نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۳۱ ب.ظ)Ava.arshad94 نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۲۲ ب.ظ)mahnaz.p نوشته شده توسط:  این چیزی ک شما میگید درستش اینه o(f)O(f)θ(f) و بعد هم فرق نماد و در این هست ک در مورد اولی ممکنه یک جاهایی هم دو طرف برابر بشن (تابعی ک انتخاب میکنید) ولی در مورد دومی میدانیم ک هیچ وقت مساوی نیستند صرفا زیرمجموعشه امکان مساوی بودن نداره.

مرسی دوست عزیز
فرموله شما درست اما چیزی که من نوشتم یه فرمول دیگه ستBig Grin و سوالم اینه که نباید اون علامت زیر مجموعه تغییر کنه؟ چون یه فرموله دیگه میگه این دو عبارتی که نوشتم برابرنیستن.پس وقتی برابر نیستن زیر مجموعه باید محض باشه و بدون اون خط کوفتیه زیرش
همین نکات ریز ممکنه بعضی وقتا از زیر دستمون در برن...

آها ببخشید حواسم نبود این فرمولیم ک شما نوشتید درسته و علامت زیر مجموعه مساوی باید باشه چون وقتی امگا رو از O کم میکنیم در واقه همون هم مرتبه ها یعنی همون تتا رو ازش کم میکنه(مرتبه های بالا ک اصلا تو O نیستند !) حالت مساوی هم پیش میاد مثلن f=n بگیرید

نه.این مثال نقضشه
تابع دو ضابطه ای که برای nهای زوج مقدار n داشته باشه و برای n های فرد مقدار ۱
اینطوری میشه fo(n) چون یه جاهای مساوی n هست و طبق تعریف little o نباید مساوی باشه
اما بااین حال fO(n)Omega(f) درسته
با این مثال نقض باید زیر مجموعه ی محض باشهHuh

این مثال نقض ماله جزوه ی استاد یوسفی هست مال منم نیست Big Grin

درسته این مثال نقضشه منم نگفتم همه جا صادقه واسه همینم نماد زیرمجموعه مساوی میزاریم نه نماد مساوی خالی!یعنی بسته به تابعی ک داریم ممکنه مساوی شه یا زیر مجموعش باشه و نه مساویRolleyes
آخ آخ آخ فکنم اشتباهمو فهمیدم. داشتم برعکس به قضیه میفکریدم بخاظر مثال نقضه
مرسی دوستم کامل افتادBlush
یافتن تمامی ارسال‌های این کاربر

ارسال: #۱۸
  

nlp@2015 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۶ تیر ۱۳۹۳ ۰۷:۳۸ ب.ظ)Ava.arshad94 نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۷:۱۶ ب.ظ)mahnaz.p نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۴۶ ب.ظ)Ava.arshad94 نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۳۹ ب.ظ)mahnaz.p نوشته شده توسط:  
(26 تیر ۱۳۹۳ ۰۶:۳۱ ب.ظ)Ava.arshad94 نوشته شده توسط:  مرسی دوست عزیز
فرموله شما درست اما چیزی که من نوشتم یه فرمول دیگه ستBig Grin و سوالم اینه که نباید اون علامت زیر مجموعه تغییر کنه؟ چون یه فرموله دیگه میگه این دو عبارتی که نوشتم برابرنیستن.پس وقتی برابر نیستن زیر مجموعه باید محض باشه و بدون اون خط کوفتیه زیرش
همین نکات ریز ممکنه بعضی وقتا از زیر دستمون در برن...

آها ببخشید حواسم نبود این فرمولیم ک شما نوشتید درسته و علامت زیر مجموعه مساوی باید باشه چون وقتی امگا رو از O کم میکنیم در واقه همون هم مرتبه ها یعنی همون تتا رو ازش کم میکنه(مرتبه های بالا ک اصلا تو O نیستند !) حالت مساوی هم پیش میاد مثلن f=n بگیرید

نه.این مثال نقضشه
تابع دو ضابطه ای که برای nهای زوج مقدار n داشته باشه و برای n های فرد مقدار ۱
اینطوری میشه fo(n) چون یه جاهای مساوی n هست و طبق تعریف little o نباید مساوی باشه
اما بااین حال fO(n)Omega(f) درسته
با این مثال نقض باید زیر مجموعه ی محض باشهHuh

این مثال نقض ماله جزوه ی استاد یوسفی هست مال منم نیست Big Grin

درسته این مثال نقضشه منم نگفتم همه جا صادقه واسه همینم نماد زیرمجموعه مساوی میزاریم نه نماد مساوی خالی!یعنی بسته به تابعی ک داریم ممکنه مساوی شه یا زیر مجموعش باشه و نه مساویRolleyes
آخ آخ آخ فکنم اشتباهمو فهمیدم. داشتم برعکس به قضیه میفکریدم بخاظر مثال نقضه
مرسی دوستم کامل افتادBlush

خواهش میکنمWink
یافتن تمامی ارسال‌های این کاربر

ارسال: #۱۹
  

Morris پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۶ تیر ۱۳۹۳ ۰۲:۰۳ ب.ظ)Ava.arshad94 نوشته شده توسط:  الان من توو تفاوت این دوتا موندم
به این فرمول رسیدم o(f)O(f)Omega(f) و گفته شده دلیلش اینه که توو سمت راستی توابعی هست که توو سمت چپی نیس. خب این که تعریفه این یکیه

سلام.
این درسته :


o(f)O(f)Omega(f)
یافتن تمامی ارسال‌های این کاربر

۰
ارسال: #۲۰
  

bernova پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

سلام دوستان
میگم برای فهمیدن مرتبه اجرایی حلقه های تودرتو وابسته در سر جلسه کنکور چه راهی بهتر از trace کردن چند مرحله از الگوریتم است که سریع به جواب برسیم
مثلا
for(i=1;i<=n;i*2)
for(j=1;j<=i;j*2
{
x++;
{

ارسال: #۲۱
  

bahman2000 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۱۰ مرداد ۱۳۹۳ ۱۲:۲۶ ق.ظ)bernova نوشته شده توسط:  سلام دوستان
میگم برای فهمیدن مرتبه اجرایی حلقه های تودرتو وابسته در سر جلسه کنکور چه راهی بهتر از trace کردن چند مرحله از الگوریتم است که سریع به جواب برسیم
مثلا
for(i=1;i<=n;i*2)
for(j=1;j<=i;j*2
{
x++;
{
نه فکر نمی کنم روش دیگه ای وجود داشته باشه خود این روش trace کردن هم به نظرم مشکل نیست اگه چند نمونه از این مساله ها حل کنید زود راه می افتید. برای مساله بالا هم با trace کردن به جواب (O(logn می رسیم.
یافتن تمامی ارسال‌های این کاربر

ارسال: #۲۲
  

bernova پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

سلام دوست عزیز
منمنون از توجه تون
لطفا به حلقه تودرتو زیر نیز یه نگاه بنداز تو جزوه امیرکبیر یه جواب داده ، پارسه هم یه جواب
مرتبه اجراییی الگوریتم زیر چقدر است
for(i=0;i<n;i++[/align]
یافتن تمامی ارسال‌های این کاربر

ارسال: #۲۳
  

bahman2000 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۱۱ مرداد ۱۳۹۳ ۱۰:۳۸ ب.ظ)bernova نوشته شده توسط:  سلام دوست عزیز
منمنون از توجه تون
لطفا به حلقه تودرتو زیر نیز یه نگاه بنداز تو جزوه امیرکبیر یه جواب داده ، پارسه هم یه جواب
مرتبه اجراییی الگوریتم زیر چقدر است
for(i=0;i<n;i++[/align]
برای حلقه ی for خالی که مرتبه تعیین نمی کنن. از روی این حلقه ای که شما نوشتید فقط تعداد دفعات تکرار خود for به اضافه ی تعداد تکرار داخل حلقه ی for مشخص می شه.اگه هدف ما تعیین مرتبه باشه بایستی دنبال دستور اصلی باشیم.
یافتن تمامی ارسال‌های این کاربر

ارسال: #۲۴
  

bernova پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

اقا شرمنده من نمیدونم چرا حلقه for اینطوری پست شد اینجا منظورم مرتبه اجرایی حلقه زیر است
for(I=1;I<n;I++)1
for(j=1;j<n;J++)1
{
x++
n++
}
بازم ببخشید
یافتن تمامی ارسال‌های این کاربر

ارسال: #۲۵
  

bahman2000 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۱۲ مرداد ۱۳۹۳ ۰۴:۳۵ ب.ظ)bernova نوشته شده توسط:  اقا شرمنده من نمیدونم چرا حلقه for اینطوری پست شد اینجا منظورم مرتبه اجرایی حلقه زیر است
for(I=1;I<n;I++)1
for(j=1;j<n;J++)1
}
x++
n--
{
{
بازم ببخشید
مراحل trace:
i=1---------------> بار n/2
i=2---------------> بار n/4
i=3---------------> بار n/8
i=4--------------> بار n/16
.....................................
i=log n---> بار n/2^ log n
جمع تعداد دفعات تکرار: (n/2+n/4+n/8+n/16+...+n/n=n(1/2+1/4+1/8+...+1/n)=n(1-1/n)=n-1=O(n
یافتن تمامی ارسال‌های این کاربر

۰
ارسال: #۲۶
  

A V A پاسخ داده:

مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۱۲ مرداد ۱۳۹۳ ۰۴:۳۵ ب.ظ)bernova نوشته شده توسط:  اقا شرمنده من نمیدونم چرا حلقه for اینطوری پست شد اینجا منظورم مرتبه اجرایی حلقه زیر است
for(I=1;I<n;I++)1
for(j=1;j<n;J++)1
{
x++
n++
}
بازم ببخشید

مطمعنین اون n++ هست و n-- نیست؟

۰
ارسال: #۲۷
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

ببینم فکر کنم --n باشه نه ++n؟

ارسال: #۲۸
  

bernova پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

اره n-- ,است . یکی از مثال های پارسه است
منظورم اینه که تو پارسه میگه O(n و جزوه امیرکبیر میگه O(nlogn به نظر من دومی است
یافتن تمامی ارسال‌های این کاربر

ارسال: #۲۹
  

sana123 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۱۲ مرداد ۱۳۹۳ ۱۰:۳۹ ب.ظ)bernova نوشته شده توسط:  اره n-- ,است . یکی از مثال های پارسه است
منظورم اینه که تو پارسه میگه O(n و جزوه امیرکبیر میگه O(nlogn به نظر من دومی است
دوستان منم فکر می کنم n log n درست باشه، چون شمارنده حلقه ها به هم وابسته نیستند تعداد تکرار حلقه ها در هم ضرب میشن.
در حلقه داخلی هر بار ۲واحد کاهش داریم چون یک بار j را می بریم جلو و یکبار از n کم می کنیم، پس حقه داخلی هربار n/2 بار اجرا میشه که مرتبه اجراییش میشه n، حالا وقتی از حلقه داخلی خارج میشم n شده n/2 یعنی بازه حلقه بیرونی شده از یک تا n/2 پس مثل اینه که گام کاهش حلقه بیرونی تقسیم بر ۲ هست که مرتبه اجراییش میشه log n ، پس مرتبه اجرایی دو حلقه میشه n log n

Big Grin کسی فهمید من چی گفتم؟ Big Grin

یافتن تمامی ارسال‌های این کاربر

ارسال: #۳۰
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

اولین بار به ازای i=1 تعداد تکرار n2 هستش و به ازای i=2 تعداد تکرار n4 هستش و به همین ترتیب.j در هر بار به اندازه n2، (n) تکرار میشه که برای بار دوم همونn4 هستش .اخرش هم مرتبه اجرا همون n میشه.,وقتی لگاریتم درسته که رشد حلقمون لگاریتمی باشه(یعنی شرط حلقه).در صورتی که اینجا اینطور نیستش
یافتن تمامی ارسال‌های این کاربر

ارسال: #۳۱
  

sana123 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

نظرتون در مورد این حلقه چیه؟
for(int i=0; i<=n; i/=2)
cout<<"*";
غیر از اینه که چون هر بار بازه داره نصف میشه مرتبه اجراییش میشه log n
الان دقیقا همین اتفاق داره واسه حلقه بیرونی می افته
یافتن تمامی ارسال‌های این کاربر

ارسال: #۳۲
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

ببینید تو مثال شما درسته شمارنده هر بار داره نصف میشه پس زمان اجرا lg(n).ولی تو مثال قبلی شمارنده داره یه واحد هر بار اضافه میشه.یعنی همیشه داریم i=1 ،بعدش i=2 بعد i=3 و همینطور تا زمانی که in.درسته؟
حالا ما باید مجموع اجرای i ها رو به دست بیاریم اکی؟
قبول دارید به ازای i=1 جمله اصلی به اندازه n2 اجرا میشه؟
و به ازای i=2 جمله اصلی به اندازه n4 اجرا میشه؟
و به ازای i=3 جمله اصلی به اندازه n8 اجرا میشه؟
و همینطوری تا اخر ادامه پیدا میکنه.

حالا میخوایم مجموع اجرای i ها رو حساب کنیم:

n2n4n8...=n(121418...)=n12112=n1212=n=θ(n)

اکی؟توی مثال شما ما مطمئنیم که به ازای هر n اون n به اندازه lg(n) بار اجرا میشه چون فقط کافیه تعداد باری که شمارنده داره اضافه میشه رو بشماریم و چون شمارنده هم داره لگاریتمی اضافه میشه پس زمان اجرا lg(n) میشه ولی تو این مثال به ازای هر i رابطه بالا برقراره.
امیدوارم براتون خوب توضیح داده باشم Smile

در ضمن فکر کنم شرط حلقتون باید *(ضرب) باشه نه /(تقسیم).
یافتن تمامی ارسال‌های این کاربر

ارسال: #۳۳
  

sana123 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۱۹ مرداد ۱۳۹۳ ۰۹:۱۵ ق.ظ)miladcr7 نوشته شده توسط:  در ضمن فکر کنم شرط حلقتون باید *(ضرب) باشه نه /(تقسیم).
خیلی ممنون توضیحت کامل بود بله شرط حلقه ضربه، حالا اگه حلقمون تودرتو نباشه و به صورت زیر باشه چی میشه؟
for(int i= 1; i<=n; i++) 1
n/=2; 1

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

ارسال: #۳۴
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

فکر کنم باید از همون مرتبه lg(n) باشه البته اگه همین یه حلقه منظورته
یافتن تمامی ارسال‌های این کاربر

ارسال: #۳۵
  

sana123 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۱۹ مرداد ۱۳۹۳ ۰۶:۰۸ ب.ظ)miladcr7 نوشته شده توسط:  فکر کنم باید از همون مرتبه lg(n) باشه البته اگه همین یه حلقه منظورته
آره منظورم همون یه حلقه اس،
حالا می دونید چی گیجم میکنه؟ اینکه توی مثال اول حلقه داخلی داره کار نصف کردن n را انجام میده پس حلقه بیرونی مثل این حلقه تکیه میشه که مرتبش لگاریتمیه
یافتن تمامی ارسال‌های این کاربر

ارسال: #۳۶
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

ببین بذار اینطور بگیم.از مثال دوم شروع میکنیم خب:

for(inti=1;i<n;i)
}
x;

n=n2
{

اینجا کار ما راحته ببین ما بازم برای زمان اجرا ،میخوایم تعداد باری که x اجرا میشه رو به دست بیاریم خب؟
حالا قبول داری به ازای i=1 جمله اصلی( که همون x1 هستش ) ۱ بار اجرا میشه؟
و به ازای i=2 جمله اصلی( که همون x1 هستش ) بازم ۱ بار اجرا میشه؟
تا وقتی که i>n برقرار شه و شرط حلقه رو نقض کنه.اکی؟
حالا برای به دست اوردن زمان اجرا ما باید تعداد این دفعات رو بشماریم خب یا مجموع این [tex]i[/tex] ها رو به دست بیاریم.حالا دقت کن این بار دیگه اینطور نیست که بگیم مثلا به ازای i=1 جمله اصلی n2 تکرار میشه و...
چون گفتیم به ازای هر [tex]i[/tex] جمله اصلی ۱ بار فقط اجرا میشه حالا ما میخوایم تعداد این [tex]i[/tex] رو به دست بیاریم
اگه برای چند عدد تست کنی میبینی که برای هر عدد n تعداد [tex]i[/tex] برابر Lg(n) میشه پس زمان اجرا هم Lg(n) میشه.هر چند با یه خرده دقت میتونستی بفهمی تقسیم شدن عدد n تو این مثال مثل ضرب یا تقسیم شدن شمارندست البته چون یه حلقه داریم ها.

حالا مثال اول. توی مثال اول ما بازم میخوایم مجموع تعداد دفعات اجرای جمله اصلی به ازای هر [tex]i[/tex] رو به دست بیاریم.دقت کن چون
حلقه تو در تو داریم پس دیگه نمیتونیم بگیم به ازای هر [tex]i[/tex] جمله اصلی یه بار اجرا میشه و چون هر بار یه واحد از مقدار n هم با اجرای جمله اصلی کم میشه پس نمیشه گفت به ازای هر [tex]i[/tex] جمله اصلی n بار تکرار میشه.حالا ما این مجموع رو حساب میکنیم اگه مجموع تعداد دفعات اجرای جمله اصلی Lg(n) شد خب حرف شما قابل قبول.پس ما همیشه برای زمان اجرا مجموع تعداد اجرای جمله اصلی رو حساب میکنیم.

حالا ما باید مجموع اجرای [tex]i[/tex] ها رو به دست بیاریم اکی؟
قبول دارید به ازای i=1 جمله اصلی به اندازه n2 اجرا میشه؟
و به ازای i=2 جمله اصلی به اندازه n4 اجرا میشه؟
و به ازای i=3 جمله اصلی به اندازه n8 اجرا میشه؟
و همینطوری تا اخر ادامه پیدا میکنه.

حالا میخوایم مجموع اجرای [tex]i[/tex] ها رو حساب کنیم:

n2n4n8...=n(121418...)=n12112=n1212=n=θ(n)

پس زمان اجرا همون θ(n) میشه.


دقت کن که جمله n باعث شده دیگه نتونیم بگیم مثلا حلقه اول دقیقا این قدر اجرا میشه و حلقه دوم هم به همچنین.اگه
n نبودش زمان اجرای حلقه رو میتونستیم به دست بیاریم ولی با این شرایط به ازای i=1 حلقه دوم یه تعداد بار اجرا میشه و به ازای i=2 یه تعداد بار دیگه.پس ما مجبوریم که مجموع این تعداد بارها رو به دست بیاریم
یافتن تمامی ارسال‌های این کاربر

ارسال: #۳۷
  

sana123 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۰ مرداد ۱۳۹۳ ۱۲:۰۳ ب.ظ)miladcr7 نوشته شده توسط:  ببین بذار اینطور بگیم.از مثال دوم شروع میکنیم خب:

for(inti=1;i<n;i)
}
x;

n=n2
{

اینجا کار ما راحته ببین ما بازم برای زمان اجرا ،میخوایم تعداد باری که x اجرا میشه رو به دست بیاریم خب؟
حالا قبول داری به ازای i=1 جمله اصلی( که همون x1 هستش ) ۱ بار اجرا میشه؟
و به ازای i=2 جمله اصلی( که همون x1 هستش ) بازم ۱ بار اجرا میشه؟
تا وقتی که i>n برقرار شه و شرط حلقه رو نقض کنه.اکی؟
حالا برای به دست اوردن زمان اجرا ما باید تعداد این دفعات رو بشماریم خب یا مجموع این [tex]i[/tex] ها رو به دست بیاریم.حالا دقت کن این بار دیگه اینطور نیست که بگیم مثلا به ازای i=1 جمله اصلی n2 تکرار میشه و...
چون گفتیم به ازای هر [tex]i[/tex] جمله اصلی ۱ بار فقط اجرا میشه حالا ما میخوایم تعداد این [tex]i[/tex] رو به دست بیاریم
اگه برای چند عدد تست کنی میبینی که برای هر عدد n تعداد [tex]i[/tex] برابر Lg(n) میشه پس زمان اجرا هم Lg(n) میشه.هر چند با یه خرده دقت میتونستی بفهمی تقسیم شدن عدد n تو این مثال مثل ضرب یا تقسیم شدن شمارندست البته چون یه حلقه داریم ها.

حالا مثال اول. توی مثال اول ما بازم میخوایم مجموع تعداد دفعات اجرای جمله اصلی به ازای هر [tex]i[/tex] رو به دست بیاریم.دقت کن چون
حلقه تو در تو داریم پس دیگه نمیتونیم بگیم به ازای هر [tex]i[/tex] جمله اصلی یه بار اجرا میشه و چون هر بار یه واحد از مقدار n هم با اجرای جمله اصلی کم میشه پس نمیشه گفت به ازای هر [tex]i[/tex] جمله اصلی n بار تکرار میشه.حالا ما این مجموع رو حساب میکنیم اگه مجموع تعداد دفعات اجرای جمله اصلی Lg(n) شد خب حرف شما قابل قبول.پس ما همیشه برای زمان اجرا مجموع تعداد اجرای جمله اصلی رو حساب میکنیم.

حالا ما باید مجموع اجرای [tex]i[/tex] ها رو به دست بیاریم اکی؟
قبول دارید به ازای i=1 جمله اصلی به اندازه n2 اجرا میشه؟
و به ازای i=2 جمله اصلی به اندازه n4 اجرا میشه؟
و به ازای i=3 جمله اصلی به اندازه n8 اجرا میشه؟
و همینطوری تا اخر ادامه پیدا میکنه.

حالا میخوایم مجموع اجرای [tex]i[/tex] ها رو حساب کنیم:

n2n4n8...=n(121418...)=n12112=n1212=n=θ(n)

پس زمان اجرا همون θ(n) میشه.


دقت کن که جمله n باعث شده دیگه نتونیم بگیم مثلا حلقه اول دقیقا این قدر اجرا میشه و حلقه دوم هم به همچنین.اگه
n نبودش زمان اجرای حلقه رو میتونستیم به دست بیاریم ولی با این شرایط به ازای i=1 حلقه دوم یه تعداد بار اجرا میشه و به ازای i=2 یه تعداد بار دیگه.پس ما مجبوریم که مجموع این تعداد بارها رو به دست بیاریم

آره کاملا توجیح شدم، گرچه هنوز نفهمیدم اشتباه کارم جاست ولی منطق استدلال شما را کاملا متوجه میشوم، (البته فکر کنم من وابستگی حلقه ها را لحاظ نمی کنم) به هر حال ممنونم ازت بابت وقتی که گذاشتی
یافتن تمامی ارسال‌های این کاربر

ارسال: #۳۸
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

فکر کنم بدونم برای چی قاطی کردی.یه چند تا مثال میزنم امیدوارم باعث نشم بیشتر قاطی کنیSmileSmileSmileSmile.

این حلقه رو در نظر بگیر:

for(inti=0;i<n;i)
}
x;
{

حالا زمان اجرا:قبول داری حلقه [tex]n[/tex] بار دستور اصلی ( که همون x; هستش ) رو اجرا میکنه که این [tex]n[/tex] بار همون تعداد اجرای شمارنده حلقه( [tex]i[/tex] ) هم هست درسته؟پس زمان اجرا میشه:θ(n)

________________________________________________________________________________​______________________-

حالا این حلقه رو در نظر بگیر:

for(inti=0;i<n;i)

}
for(intj=0;j<n;j)
}
x;
{
{

حالا زمان اجرا:قبول داری به ازای هر [tex]i[/tex] حلقه دومی به اندازه [tex]n[/tex] بار اجرا میشه و متعاقبا جمله اصلی هم [tex]n[/tex] بار
تکرار میشه؟
ولی یه مسئله ای که باید بهش دقت کنی اینه که به ازای هر [tex]i[/tex] از حلقه اول، حلقه دومی داره به اندازه ثابتی اجرا میشه درسته؟
پس برای همین ما میتونیم بگیم که طبق اصل شمارش تعداد اجرای دستور اصلی میشه:
به ازای هر [tex]i[/tex] ،جمله اصلی [tex]n[/tex] بار تکرار میشه پس به ازای [tex]n[/tex] بار میشه :nn که
زمان اجرا میشه :θ(n2)

ببین حالا نکته اینجاست:وقتی مثلا دو حلقه تو در تو داریم زمانی میتونی تعداد اجرای حلقه بیرونی رو مستقل از حلقه دوم بگی( مثلا بگی حلقه بیرونی [tex]n[/tex] بار اجرا میشه و حلقه تویی lg(n) بار) که به ازای هر [tex]i[/tex] توی حلقه اول، حلقه دوم به تعداد lg(n) بار اجرا بشه که نیازی نباشه مجموع بگیری ولی اگه به ازای هر [tex]i[/tex] از حلقه اولی ،حلقه دوم به تعداد متغیری اجرا شد دیگه نمیتونی زمان اجرای حلقه اول رو همینطوری مستقل بگی میدونی چرا؟مثال زیر رو داشته باش


for(inti=0;i<n;i)

}
for(intj=0;j<i;j)
}
x;
{
{


خب حالا سوال من اینه : حلقه اول [tex]n[/tex] بار اجرا میشه درسته؟ ولی ایا میتونی برای محاسبه تعداد دفعات اجرای جمله اصلی بیای
از این روش بری که بگی حلقه اول [tex]n[/tex] بار تکرار میشه ؟نه نمیتونی چون به ازای هر [tex]i[/tex] توی حلقه اول ،حلقه دوم داره به یه مقدار متغیر اجرا میشه مثلا به ازای i=1 حلقه دوم ۱ بار و به ازای i=2 حلقه دوم ۲ بار و همینجوری.خب الان اگه برای به دست اوردن تعداد دفعه اجرای جمله اصلی بیایم بگیم حلقه اول [tex]n[/tex] بار اجرا میشه اون وقت برای حلقه دوم چی بگیم؟مگه نباید توی این روش تعداد دفعه اجرای حلقه دوم رو توی تعداددفعه اجرای حلقه اول ضرب کنیم؟ولی میبینی نمیتونیم این کار رو انجام بدیم چون تعداد دفعه اجرای حلقه دوم به ازای هر بار اجرای حلقه اول متغیره اکی؟
پس مجبوریم مجموع تعداد دفعات اجرای حلقه دوم رو به ازای هر بار اجرای حلقه اول محاسبه کنیم که تو این مثال داریم:

به ازای هر [tex]i[/tex] حلقه دوم از ۱ تا j متغیره و [tex]i[/tex] بار تکرار میشه.
یعنی به ازای i=1 حلقه دوم ۱ بار و به ازای i=2 حلقه دوم ۲ بار و همینجوری پس زمان اجرا:

123...n=n(n1)2=θ(n2)


________________________________________________________________________________​________________

حالا توی مثال خودمون اگه بگی حلقه اول lg(n) بار داره تکرار میشه برای حلقه دوم چی میگی؟
در ضمن برای حلقه دوم هم دقت کن نمیتونیم بگیم زمان اجراش θ(n) چون هر بار [tex]n[/tex] داره عوض میشه پس باید بیایم مجموع این تعداد اجراها رو به دست بیاریم یعنی به ازای i=1 حلقه دوم چند بار اجرا میشه و به ازای i=2 حلقه دوم چند بار تکرار میشه.ما از این روش استفاده کردیم چون به ازای هر [tex]i[/tex] تو حلقه اول ،حلقه دوم به مقدار متغیری داره اجرا میشه پس باید مجموع این اجراها رو به دست بیاریم.ولی اگه بگیم حلقه اول lg(n) بار داره تکرار میشه اون وقت تعداد اجرای حلقه دوم رو نداریم یه بار n2 بار اجرا میشه و یه بار n4 و ....
وقتی هم داریم مجموع این تعداد اجراها رو به دست بیاریم در واقع زمان اجرای کل رو داریم به دست میاریم

________________________________________________________________________________​________________________

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

۰
ارسال: #۳۹
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

به نظر من همون مرتبه n درسته

ارسال: #۴۰
  

bernova پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

براساس تریس که کردین شد n
یافتن تمامی ارسال‌های این کاربر

۰
ارسال: #۴۱
  

hamid88 پاسخ داده:

مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

دوستان این روابط بازگشتی و این چیزارو با کدوم کتاب خوب یاد میگیرم.
هیچ جوره من یادش نمیگیرم

۰
ارسال: #۴۲
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

اره یه تریس کنید معلوم میشه

۰
ارسال: #۴۳
  

A V A پاسخ داده:

مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۱ مرداد ۱۳۹۳ ۰۹:۱۸ ق.ظ)miladcr7 نوشته شده توسط:  خواهش میکنم.چه اشتباهی رو متوجه نشدی بگو شاید تونستم کمکت کنم؟

نحوه توضیح دادنت چقد مث من شدهSmile
افرین بچه ها که انقدر بهم کمک میکنین، هر وقت میام مانشت احساس خوبه رقابت سالم رو حداقل توو چندتا تاپیک حس میکنم
من چند روزه توو موود ساختمان نیستمSad

ارسال: #۴۴
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

سلام خسته نباشید.اره دیگه ازت یاد گرفتم SmileSmileSmileSmileSmile
یافتن تمامی ارسال‌های این کاربر

۰
ارسال: #۴۵
  

ƊƦЄƛM پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

سلام دوستان
لطفا اگه کسی میتونه به این سوالم جواب بده. مرسی

مهمان عزیز شما قادر به مشاهده پیوندهای انجمن مانشت نمی‌باشید. جهت مشاهده پیوندها ثبت نام کنید.

ارسال: #۴۶
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

بله همون الگوریتم جایگشت هستش
یافتن تمامی ارسال‌های این کاربر

۰
ارسال: #۴۷
  

A V A پاسخ داده:

مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۲۹ مرداد ۱۳۹۳ ۰۶:۴۵ ب.ظ)miladcr7 نوشته شده توسط:  بله همون الگوریتم جایگشت هستش

توو تاپیکه خودش یکم توضیح میدی؟ منم گیج شدم


Sent from my iPad using
مهمان عزیز شما قادر به مشاهده پیوندهای انجمن مانشت نمی‌باشید. جهت مشاهده پیوندها ثبت نام کنید.

ارسال: #۴۸
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

چیشو توضیح بدم؟
یافتن تمامی ارسال‌های این کاربر

۰
ارسال: #۴۹
  

MiladCr7 پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

خب صورت اصلی که اینه:T(n)=5T(n5)nlgn

خب پایه لگاریتم دو هستش و ما هر بار داریم به جای n مقدار میذاریم ،پایه که تغییر نمیکنه.توی مثال صفحه ۴۲ هم اینطور بود بازم همون پایه لگاریتم ۲ بود.
ولی فرقش این بود که هر بار n2 یا n4 یا .... میشد که اینا توان دو هستن

مثلا:
lgn82=lgn2lg82=lgn23

حالا این مثال هم اینطوره دیگه:
مثلا توی سطح دوم داریم:
lgn252=lgn2lg252=lgn22lg52

اشتباه میگم؟Huh

۰
ارسال: #۵۰
  

ldns0098 پاسخ داده:

Re: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

سلام. بچه ها تو کتاب مقسمی یه چیزی بیان شده که برا من عجیبه! به این صورت که اگر k=0 باشه، جواب این عبارت صفر میشه:
a[i] = k++
ینی:
a[i] = 0
و این برخلاف چیزیه که من تا حالا میدونستم. آیا من درست متوجه موضوع نشدم یا توضیح مقسمی مشکل داره؟ در ضمن این مربوط به سوال ۱۵ صفحه ۲۸ کتابشه.

۰
ارسال: #۵۱
  

e2000 پاسخ داده:

Re: RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

(۰۲ مهر ۱۳۹۳ ۰۸:۰۷ ب.ظ)ldns0098 نوشته شده توسط:  سلام. بچه ها تو کتاب مقسمی یه چیزی بیان شده که برا من عجیبه! به این صورت که اگر k=0 باشه، جواب این عبارت صفر میشه:
a[i] = k++
ینی:
a[i] = 0
و این برخلاف چیزیه که من تا حالا میدونستم. آیا من درست متوجه موضوع نشدم یا توضیح مقسمی مشکل داره؟ در ضمن این مربوط به سوال ۱۵ صفحه ۲۸ کتابشه.

سلام، ببینید عبارات ++k و k++ با هم فرق دارن، در عبارتی که شما گفتید چون شکل اولی رو گذاشته یعنی اول محتوای k رو بریز تو a ،بعد یکی به k اضافه کن. اما اگه شکل دوم یعنی k++ به کار رفته بود ،یعنی اول یکی به k اضافه کن بعد بریزش تو a .

۰
ارسال: #۵۲
  

raeika پاسخ داده:

RE: مطالعه و رفع اشکال گروهی درس ساختمان داده(ارشد ۹۴)

سلام خواستم بدونم سوالات مربوط به لیستای پیوندی چطور حل میشن
مثل این سوال
[تصویر:  391184_bdrf2rdhzq8ng53h9mh1.jpg]



موضوع‌های مرتبط با این موضوع...
موضوع: نویسنده پاسخ: بازدید: آخرین ارسال
Lightbulb مطالعه گروهی کارمندان برای کنکور ارشد ۱۴۰۳ deniz22 ۰ ۶۲۴ ۲۹ آبان ۱۴۰۲ ۱۱:۴۲ ق.ظ
آخرین ارسال: deniz22
  خواندن گروهی کنکور دکتری هوش ۹۹ Lootus ۹ ۹,۱۴۰ ۰۴ تیر ۱۴۰۲ ۰۱:۴۷ ب.ظ
آخرین ارسال: solmaz58
  بهترین منبع برای درس شبکه ارشد msnmkh ۲ ۱,۸۲۴ ۱۲ دى ۱۴۰۱ ۱۲:۵۵ ق.ظ
آخرین ارسال: پشتکار
Question بهترین منبع ساختمان داده برای کنکور ارشد marvelous ۱۰ ۱۲,۷۸۴ ۱۵ آذر ۱۴۰۱ ۰۷:۵۶ ب.ظ
آخرین ارسال: msnmkh
  فیلم آموزش ساختمان داده negin_bt ۰ ۱,۳۲۶ ۲۰ مهر ۱۴۰۱ ۰۷:۵۶ ب.ظ
آخرین ارسال: negin_bt
  مطالعه گروهی ارشد ۱۴۰۰ persiancoder ۹ ۶,۱۹۰ ۱۹ دى ۱۳۹۹ ۰۷:۱۷ ب.ظ
آخرین ارسال: nasser89
  رفع اشکال نصب جاوا، مشکل ساخته نشدن virtual machine shiivaa ۱۲ ۲۱,۰۸۸ ۱۹ آبان ۱۳۹۹ ۰۷:۲۹ ب.ظ
آخرین ارسال: wanted471
  نوشتن مقاله به صورت گروهی osho ۰ ۲,۰۷۶ ۱۶ آبان ۱۳۹۹ ۱۱:۵۵ ق.ظ
آخرین ارسال: osho
  معرفی کتاب برای ساختمان داده siamakaf ۲ ۴,۷۶۱ ۱۲ آبان ۱۳۹۹ ۰۹:۲۱ ق.ظ
آخرین ارسال: siamakaf
  چگونه این خطا را موقع اجرای sql server 2014 رفع کنم ؟ farahnaz ۲ ۳,۱۲۹ ۱۹ مهر ۱۳۹۹ ۰۲:۱۸ ق.ظ
آخرین ارسال: farahnaz

پرش به انجمن:

Can I see some ID?

به خاطر سپاری رمز Cancel

Feeling left out?


نگران نباش، فقط روی این لینک برای ثبت نام کلیک کن. رمزت رو فراموش کردی؟ اینجا به یادت میاریم! close

رمزت رو فراموش کردی؟

Feeling left out?


نگران نباش، فقط روی این لینک برای ثبت نام کلیک کن. close