-
Notifications
You must be signed in to change notification settings - Fork 103
/
list.c
76 lines (68 loc) · 1.26 KB
/
list.c
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
#include <stdio.h>
//单链表的一些练习
typedef struct listNode
{
int data;
struct listNode *next ;
}listNode,*list;
list CreateList(int *str, int len)
{
int i;
listNode *head, *node, *tmp;
if (str == NULL || len == 0)
return NULL;
head = (list)malloc(sizeof(listNode));
head->next = NULL;
for (i = 0; i < len - 1; i++)
{
node = (list)malloc(sizeof(listNode));
node->data = str[i];
tmp = head->next;
head->next = node;
node->next = tmp;
}
head->data = str[i];
return head;
}
list reverseList(list l)
{
list head, tmp;
head = tmp = NULL;
while (l != NULL)
{
tmp = head;
head = l;
l = l->next;
head->next = tmp;
}
return head;
}
void printList(list head)
{
if (head == NULL)
return;
while (head != NULL)
{
printf("%d ", head->data);
head = head->next;
}
}
list mergeList(list a, list b)
{
list head = NULL;
if (a == NULL)
return b;
if (b == NULL)
return a;
if (a->data > b->data)
{
head = a;
head->next = mergeList(a->next, b);
}
else
{
head = b;
head->next = mergeList(a, b->next);
}
return head;
}