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

نکات - لیست پیوندی

ارسال:
  

Masoud05 پرسیده:

نکات - لیست پیوندی

منتظر ارسال شماییم!!!

۳
ارسال:
  

yaser_ilam_com پاسخ داده:

RE: نکات - لیست پیوندی

لیست پیوندی

۱) لیست پیوندی ساختمان داده ای پویاست.
۲) جستجو در لیست پیوندی همواره خطی(ترتیبی) است.
۳) جستجوی دودویی در لیست پیوندی قابل پیاده سازی نیست.
۴) برای حذف گره از لیست خطی نیاز است یک اشاره گر تغییر کند.
۵) درج گره در لیست پیوندی خطی نیاز به تغییر دو اشاره گردارد.
۶) در صورتی که تعدادعناصر مورد استفاده مشخص باشد بکار گرفتن آرایه بهتر از کار با لیست پیوندی است.
۷)برای درج گره ی جدید بعد از گره ی p در لیست خطی داریم:
;(New(q
;q.Data=Item
;q.Next=p.Next
;p.Next=q


۹) درج عنصر جدید در صف پیوندی به انتهای لیست است و حذف از ابتداست.
۱۰) حذف و درج عنصر جدید درپشته ی پیوندی به ابتدای لیست غیر تهی است.

لیست پیوندی یا فهرست پیوندی (به انگلیسی: Linked list) ساختاری شامل دنباله‌ای از عناصر است که هر عنصر دارای اشاره‌گری به عنصر بعدی در دنباله است. لیست پیوندی از جملهٔ ساده‌ترین و رایج‌ترین داده‌ساختارها است و در پیاده‌سازی از داده‌ساختارها پشته (Stack)، صف (Queue) و جدول درهم‌سازی (Hash table) استفاده می‌شود. مزیت مهم لیست پیوندی نسبت به آرایه‌ها این است که ترتیب قرار گرفتن داده‌ها در آن با ترتیب قرار گرفتن آن‌ها در حافظه متفاوت است. به همین دلیل لیست پیوندی دارای این ویژگی است که درج و حذف گره‌ها در هر نقطه‌ای از لیست، با تعداد ثابتی از عملیات امکان‌پذیر است. از طرف دیگر لیست پیوندی اجازه دستیابی تصادفی به داده یا هرگونه اندیس گذاری را نمی‌دهد. در نتیجه بسیاری از اعمال ابتدایی نظیر به دست آوردن آخرین عنصر لیست، پیدا کردن عنصر شامل داده مورد نظر، یا مشخص کردن مکان درج یک عنصر جدید ممکن است نیازمند بررسی اکثر عناصر لیست باشد.

مفاهیم ابتدایی

هر عنصر در یک لیست پیوندی گره نامیده می‌شود. هر گره شامل یک فیلد کلید و یک فیلد اشاره‌گر است.

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

لیست دوپیوندی
در یک لیست دوپیوندی، هرگره علاوه بر اشاره‌گری به عنصر بعدی دارای اشاره‌گری به عنصر قبلی خود نیز می‌باشد. در این نوع ساختمان داده هر گره یا node دو پوینتر دارد به نام‌های back,front که برای اتصال گره‌ها استفاده می گردد.

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


تذکر: تهی قرار دادن فیلد next آخرین گره برای تشخیص انتهای لیست ضروری است.

در ادامه این بحث فرض می‌گیریم گره‌های لیست از نوع myrec - شامل عنصری به نام next از نوع اشاره گر به خود - هستند.
در ابتدا، همیشه باید دو اشاره‌گر عمومی (مثلا به نامهای first و last) تعریف کنید که یکی به ابتدای لیست و دیگری به انتهای آن اشاره کنند. در لیست‌های پیوندی اگر آدرس عنصر اول را داشته باشید، می‌توانید به همه عناصر دسترسی پیدا کنید. عنصر آخر هم زمان اضافه کردن گره جدید به کار می‌آید. با داشتن آدرس این گره در زمان اضافه کردن گره جدید، لازم نیست لیست را از ابتدا تا انتها برای یافتن آخرین گره پیمایش کنید. پس وجود این اشاره‌گرها مهم بوده و حتما باید تعریف شوند. در تعریف این اشاره‌گرها باید به دو نکته توجه کرد:
۱- باید عمومی تعریف شوند. اگر از کلاس استفاده می‌کنید، باید عضو مستقیم و خصوصی کلاس باشند.
۲- باید در زمان تعریف با تهی (NULL برای ++C) مقداردهی شوند. مانند عبارت‌های زیر:

;myrec *first = NULL
;myrec *last = NULL

یادآوری: برای دسترسی به عناصر یک ساختمان توسط اشاره‌گر دو روش وجود دارد:

first->next
*first).next)

این دو دستور معادل هستند، اما اولی کمی بامسماتر است.

---------------------------------------------------------------------------------------------------
اعمال لیست پیوندی


اضافه کردن گره به لیست پیوندی:

وظیفه تابع add اضافه کردن یک گره به انتهای لیست پیوندی است. این تابع باید یک ورودی - شامل اطلاعات گره جدید - داشته باشد و نیازی به خروجی ندارد. البته می‌توان خروجی را از نوع بولی تعریف کرد که نشان می‌دهد عملیات با موفقیت انجام شده است یا نه؟

(void add( myrec info
}
; myrec *temp
; temp = new myrec
; temp = info*
; (if( first == NULL
}
; first = temp
; first->next = NULL
; last = first
{
else
}
; last->next = temp
; last = temp
; last->next = NULL
{


این تابع، ابتدا با دستور new یک فضا برای گره جدید رزرو می‌کند، و آدرس آن را در متغیر temp قرار می‌دهد. سپس محتوای info را در temp کپی می‌کند. دستورات مهم از اینجا شروع می‌شوند: ابتدا بررسی می‌کند که آیا first تهی است یا نه؟ اگر تهی باشد، یعنی لیست خالی است و گره جدید اولین گره لیست خواهد بود. پس temp را در first و last (چون لیست خالی بود، گره اول همان گره آخر هم می‌شود) کپی می‌کند. اگر first تهی نبود، تنها محل last را تغییر می‌دهد.


حذف یک گره از لیست پیوندی:

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

(void del( unsigned long id
}
;myrec *prior , *cur
;cur = first
;prior = NULL
( while( cur != NULL && cur->id != id
}
;prior = cur
;cur = cur->next
{
(if( cur == NULL
}
;return
{
(if( cur == first
}
;first = first -> next
(if( cur == last
}
;last = NULL
{
{
(else if( cur == last
}
;last = prior
{
else
}
; prior->next = cur->next
{
;delete cur
{

این تابع ابتدا گره با id مورد نظر را در لیست جستجو می‌کند. اگر چنین گرهی پیدا نشد، بدون انجام عمل دیگری از تابع خارج می‌شود. اشاره‌گر cur به گره حذف‌شدنی اشاره دارد و اشاره‌گر prior به گره قبل از cur. چهار حالت برای گره حذف‌شدنی وجود دارد:
۱- هم گره اول باشد و هم گره آخر.
۲- تنها گره اول باشد.
۳- تنها گره آخر باشد.
۴- نه گره اول باشد و نه گره آخر.
کد بالا برای هر چهار حالت عملیاتی را که لازم است انجام می‌دهد. برای درک بهتر عملکرد تابع فوق، آن را به صورت خط به خط به ازای گره‌هایی که در چهار وضعیت ذکر شده قرار دارند ردیابی کنید.
ما به اشاره‌گر prior نیاز داریم تا بتوانیم گره‌های قبل و بعد از cur را به هم متصل کنیم. حذف یک گره از لیست مانند آن است که حلقه‌ای را از وسط زنجیر جدا کنید. بعد از حذف حلقه، دو تکه زنجیر را باید به هم وصل کرد تا زنجیر کامل به دست بیاید.
آخرین خط تابع فضای cur را نیز که دیگر نیازی به آن نداریم آزاد می‌کند.


درج یک گره در لیست پیوندی:

تایع insert یک گره را به هر نقطه دلخواه لیست پیوندی اضافه می‌کند. این تابع دو ورودی دارد: ورودی اول اطلاعات گره جدید و ورودی دوم محل درج گره، که عموما توسط کلید مشخص می‌شود. به این معنی که گره جدید قبل از گره با کلید مشخص شده قرار می‌گیرد.
 
(void insert( myrec info, unsigned long id
}
  ;myrec *prior, *cur, *temp
  ;cur = first
  ;prior = NULL
  (while( cur != NULL && cur->id != id
  }
   ; prior = cur
   ; cur = cur->next
 {
  (if( cur == NULL
  }
    ;return
  {
  ;temp = new myrec
  ;temp = info*
  ;prior->next = temp
  ;temp->next = cur
{
 
در اینجا از سه اشاره‌گر استفاده کرده شده است: اشاره‌گر cur برای اشاره به گره جاری، اشاره‌گر prior برای اشاره به گره قبل از cur و بالاخره اشاره‌گر temp برای اشاره به گره جدید. این تابع گره با id تعیین شده را پیدا کرده و گره جدید را قبل از آن درج می‌کند. در واقع گرهی که temp به آن اشاره دارد بین گره‌های cur و prior قرار می‌گیرد.


فایل‌(های) پیوست شده


۰
ارسال:
  

liliana پاسخ داده:

نکات - لیست پیوندی

میتونید این کدها روبه زبان ++c بنویسید .مشکل من اینه که با زبان c آشنایی ندارم و کاملا گیج شدم.ممنون میشم کمکم کنید.

ارسال:
  

naderx پاسخ داده:

RE: نکات - لیست پیوندی

(۲۰ خرداد ۱۳۹۱ ۱۲:۳۴ ب.ظ)liliana نوشته شده توسط:  میتونید این کدها روبه زبان ++c بنویسید .مشکل من اینه که با زبان c آشنایی ندارم و کاملا گیج شدم.ممنون میشم کمکم کنید.

کدام کد رو میخواهید ؟ صورت سوال رو مطرح کنید تا بنویسیم.
به نظر من اول باید فصل اشاره گر ها در c ویا c++ رو بخوانید و بعد لیست یاد بگیرید.
توصیه من اینه که به کتاب ساختمان داده های جعفر نژاد قمی رجوع کنید.
یافتن تمامی ارسال‌های این کاربر



موضوع‌های مرتبط با این موضوع...
موضوع: نویسنده پاسخ: بازدید: آخرین ارسال
  جزوه خلاصه نکات مهم فصول ابتدایی درس مهندسی نرم افزار Happiness.72 ۱ ۳,۹۱۰ ۱۳ خرداد ۱۴۰۱ ۰۶:۲۸ ب.ظ
آخرین ارسال: M o h m m @ d
  نکات کنکوری روز خواستگاری Fardad-A ۳۷ ۳۵,۹۳۵ ۰۵ دى ۱۳۹۸ ۰۶:۳۳ ب.ظ
آخرین ارسال: Behnam‌
  نکات کتاب طراحی الگوریتم نارنجی پوران پژوهش(نوشته ی خود آقای یوسفی) Milad_Hosseini ۱ ۵,۰۵۹ ۱۵ آبان ۱۳۹۷ ۰۶:۳۷ ب.ظ
آخرین ارسال: asdasdasdasd
  نکات کلیدی در چاپ کاتالوگ (قسمت اول) melinaa ۰ ۱,۹۵۸ ۰۴ شهریور ۱۳۹۷ ۱۰:۲۸ ق.ظ
آخرین ارسال: melinaa
Lightbulb نکات کاربردی جهت پایان نامه/مقاله نویسی αɾια ۱۳ ۹,۱۲۴ ۱۹ فروردین ۱۳۹۷ ۰۹:۴۶ ب.ظ
آخرین ارسال: nlp@2015
  [نکات زندگی] ۱۰ شرایط خطرناک برای ازدواج ! farazin ۱۷ ۱۹,۰۲۴ ۲۳ دى ۱۳۹۶ ۰۲:۴۴ ب.ظ
آخرین ارسال: WILL
  [نکات زندگی] مـرا همـانگـونه کـه هستـم دوسـت داشتـه بـاش! good-wishes ۶ ۹,۹۷۸ ۲۳ دى ۱۳۹۶ ۱۰:۱۴ ق.ظ
آخرین ارسال: royka
  [نکات زندگی] زبانش را بشناسید تا حرف دلش را بفهمید good-wishes ۱ ۳,۵۳۱ ۰۶ دى ۱۳۹۶ ۱۲:۳۹ ق.ظ
آخرین ارسال: αɾια
  نکات قابل توجه برای کسب رتبه اول موتور های جستجو را یاد بگیرید itzeroone ۰ ۱,۵۳۶ ۱۰ مرداد ۱۳۹۶ ۰۴:۳۸ ب.ظ
آخرین ارسال: itzeroone
  دانلود نکات و خلاصه مهندسی نرم افزار پرسمن ویرایش هفتم it_2014 ۷ ۲۰,۹۴۹ ۰۵ مهر ۱۳۹۵ ۰۱:۱۲ ب.ظ
آخرین ارسال: reticent

پرش به انجمن:

Can I see some ID?

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

Feeling left out?


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

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

Feeling left out?


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