c++实现泛型循环链表
时间: 2023-03-24 09:03:21 浏览: 148
可以使用 void 指针来实现泛型循环链表,具体实现方法可以参考以下代码:
```
typedef struct node {
void *data;
struct node *next;
} Node;
typedef struct {
Node *head;
Node *tail;
int size;
} List;
List *list_create() {
List *list = (List *)malloc(sizeof(List));
list->head = NULL;
list->tail = NULL;
list->size = ;
return list;
}
void list_add(List *list, void *data) {
Node *node = (Node *)malloc(sizeof(Node));
node->data = data;
node->next = NULL;
if (list->head == NULL) {
list->head = node;
list->tail = node;
node->next = node;
} else {
list->tail->next = node;
node->next = list->head;
list->tail = node;
}
list->size++;
}
void list_remove(List *list, void *data) {
Node *prev = list->tail;
Node *curr = list->head;
int i;
for (i = ; i < list->size; i++) {
if (curr->data == data) {
if (curr == list->head) {
list->head = curr->next;
list->tail->next = list->head;
} else if (curr == list->tail) {
list->tail = prev;
list->tail->next = list->head;
} else {
prev->next = curr->next;
}
free(curr);
list->size--;
return;
}
prev = curr;
curr = curr->next;
}
}
void list_destroy(List *list) {
Node *curr = list->head;
int i;
for (i = ; i < list->size; i++) {
Node *temp = curr;
curr = curr->next;
free(temp);
}
free(list);
}
```
以上代码实现了一个泛型循环链表,可以存储任意类型的数据。
阅读全文
相关推荐
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="application/x-rar"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/e09fa/e09fa4d37aa4b8ac63bbefa75d17fdf661f74dab" alt="doc"
data:image/s3,"s3://crabby-images/e09fa/e09fa4d37aa4b8ac63bbefa75d17fdf661f74dab" alt="-"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/a328d/a328d6a6859eceb4fd8b0788ab1ea4dca20a7b0e" alt="-"
data:image/s3,"s3://crabby-images/a328d/a328d6a6859eceb4fd8b0788ab1ea4dca20a7b0e" alt="-"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/a328d/a328d6a6859eceb4fd8b0788ab1ea4dca20a7b0e" alt="-"