سورس استفاده از لیست پیوندی (Linked List) به زبان C
در این بخش سورس استفاده از لیست پیوندی (Linked List) به زبان C را برای شما آماده کرده ایم که با استفاده از نرم افزار Visual Studio با زبان برنامه نویسی C نوشته شده است. در ادامه می توانید توضیحات، تصاویر و همچنین فیلمی از نحوه اجرا شدن پروژه را مشاهده کنید.
توضیحات پروژه
لیست پیوندی (یا همان Linked List) یک نوع ساختار داده خطی است که برخلاف آرایه ها در آن عناصر به صورت پشت سر هم در حافظه قرار نمی گیرند. در لیست پیوندی هر یک از گره ها به گره بعد از خود اشاره می کند. شکل زیر نشان دهنده این موضوع است:
در این پروژه، بعد از اجرا شدن برنامه یک منوی 6 گزینه ای شامل موارد زیر به کاربر نمایش داده می شود:
- Add
- Delete
- Search
- Sort
- Quit
در لیست فوق، گزینه اول برای افزودن گره جدید به لیست استفاده می شود. گزینه دوم برای حذف یک گره از لیست استفاده می شود. گزینه سوم برای جستجوی یک گره در لیست استفاده می شود. گزینه چهارم محتویات لیست را مرتب می کند. گزینه پنجم محتویات لیست را در خروجی چاپ می کند. گزینه آخر هم برای خروج از برنامه استفاده می شود.
شما با مشاهده سورس کد این پروژه می توانید نحوه کار با اشاره گرها، تخصیص حافظه، آزاد سازی حافظه و غیره آشنا شده و مهارت خودتان در برنامه نویسی ارتقا دهید.
نکته! این پروژه با استفاده از نرم افزار Visual Studio 2019 نوشته شده است.
قسمت های از سورس کد
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 | #include <stdio.h> #include <stdlib.h> #define TRUE 1 #define FALSE 0 typedef enum { ADD = 1, DELETE = 2, SEARCH = 3, SORT = 4, PRINT = 5, QUIT = 6 } Options; typedef struct Node { int data; struct Node* next; } Node; Node* head; Node* front; short isAppRunning = TRUE; int pause(); int clearScreen(); void printMenu(); void handleUserSelection(); void getDataFromInput(const char*, int*); void addNode(); void deleteNode(); void searchNode(); void swap(Node*, Node*); void sortList(); void printList(); int main() { do { printMenu(); handleUserSelection(); } while (isAppRunning); return 0; } void deleteNode() { if (head == NULL) return; Node* node = head; Node* prevNode = NULL; int data = 0; short isDeleted = FALSE; getDataFromInput("Enter node data to delete >>> ", &data); if (node->data == data) { head = node->next; free(node); isDeleted = TRUE; } else { while (node != NULL && node->data != data) { prevNode = node; node = node->next; } if (node && prevNode && node != NULL) { prevNode->next = node->next; isDeleted = TRUE; } if (front->data == data) { free(front); front = prevNode; } } if (isDeleted) printf("%d Has Been Deletedn", data); else printf("%d Not Foundn", data); } void printList() { Node* node = head; while (node != NULL) { printf("{%d}", node->data); if (node->next != NULL) printf(" => "); node = node->next; } printf("n"); } |
هیچ نظری ثبت نشده است