پیدا کردن گره مابعد در حذف از درخت جستجوی دودویی - نسخهی قابل چاپ |
پیدا کردن گره مابعد در حذف از درخت جستجوی دودویی - sina_n - 19 شهریور ۱۳۸۹ ۰۴:۱۲ ب.ظ
تو کتاب طورانی در قسمت حذف از درخت جستجوی دودویی گفته: اگه گرهای که میخواهیم حذف کنیم دو فرزند داشت باید ابتدا گره مابعد یا ماقبل آنرا در پیمایش inorderپیدا کنیم و اونو به جای این گره بزاریم برای پیدا کردن گره مابعد این کد رو داده Tree_Successor(x) { ۱ if right[x]!= nil ۲ then return Tree _Minimum(right[x]); ۳ y = parent[x]; ۴ while y!= nil and x = right[y]; ۵ x = y; ۶ y = parent[y]; ۷ return y; { تا دستور ۲ کافیه دیگه بقیش واسه چیه گره مابعد کوچکترین گرهای است که از گرهای که میخواهیم حذف کنیم بزرگتره اصلا از دو به بعدشو نمیفهمم اگه کسی ازش سردرآورد لطفا واسم توضیح بده |
پیدا کردن گره مابعد در حذف از درخت جستجوی دودویی - luna - 19 شهریور ۱۳۸۹ ۰۵:۲۶ ب.ظ
تا خط ۲ حالتی رو داره توضیح میده که ما دنبال گره ای هستیم که فرزند راست داره که در اون صورت به زیرشاخه راست میریم و min رو پیدا میکنیم از خط ۲ به بعد حالتی هست که درخت فرزند راست نداره برای همین باید به پدر گره بره . حالا اگه x فرزند راست گره پدر باشه، گره پدر از x کوچکتر هست واسه همین پدر x رو برابر با خود x قرار میدیم و همین عمل رو تکرار می کنیم! این تکرار تا جایی ادامه پیدا می کنه که x فرزند چپ پدرش باشه! اون موقع پدر x می شه گره ما بعد x اولیه! اگه شکل این حالت رو بکشی راحت متوجه می شه. اگه جاییش رو نفهمیدی بگو بیشتر بگم. |
پیدا کردن گره مابعد در حذف از درخت جستجوی دودویی - luna - 20 شهریور ۱۳۸۹ ۱۲:۲۲ ق.ظ
(۱۹ شهریور ۱۳۸۹ ۰۴:۱۲ ب.ظ)sina_n نوشته شده توسط: اگه گرهای که میخواهیم حذف کنیم دو فرزند داشت باید ابتدا گره مابعد یا ماقبل آنرا در پیمایش inorderپیدا کنیم و اونو به جای این گره بزاریم فقط یه چیزی رو باید اضافه کنم که این الگوریتم، الگوریتم کلی پیدا کردم گره مابعد در درخت جستجوی دودویی هست و ربطی به شرطی که برای حذف در جمله قبلش( دو فرزند داشته باشه) گفتید نداره. |
پیدا کردن گره مابعد در حذف از درخت جستجوی دودویی - luna - 20 شهریور ۱۳۸۹ ۰۱:۱۲ ق.ظ
این شکل رو هم نگاه کن. تو این شکل خط های قرمز که از گره به گره های سمت راستش کشیده شده successor گره رو نشون میده |
پیدا کردن گره مابعد در حذف از درخت جستجوی دودویی - luna - 20 شهریور ۱۳۸۹ ۰۱:۱۵ ق.ظ
این شکل رو هم بررسی کن. تو این شکل خط های قرمز که از هر گره به سمت راست خارج شده به گره successor اشاره داره: |
پیدا کردن گره مابعد در حذف از درخت جستجوی دودویی - luna - 20 شهریور ۱۳۸۹ ۰۱:۱۵ ق.ظ
این شکل رو هم بررسی کن. تو این شکل خط های قرمز که از هر گره به سمت راست خارج شده به گره successor اشاره داره: مهمان عزیز شما قادر به مشاهده پیوندهای انجمن مانشت نمیباشید. جهت مشاهده پیوندها ثبت نام کنید. |
پیدا کردن گره مابعد در حذف از درخت جستجوی دودویی - csharpisatechnology - 17 آبان ۱۳۹۱ ۰۴:۵۷ ب.ظ
دوست عزیز الگوریتم غلط می باشد و ابهامات زیادی دارد. |