-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy path2015_code_link.cpp
44 lines (40 loc) · 1.05 KB
/
2015_code_link.cpp
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
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct node {
int data;
struct node* link;
}NODE;
void create(NODE* p, int a[], int pos, int length) {
if (pos < length) {
p->data = a[pos];
p->link = (NODE*)malloc(sizeof(NODE));
p->link->data = INT_MIN;//用INT_MIN作为结束标志
create(p->link, a, pos + 1, length);
}
}
void deleteNode(NODE* p, int n, int length) {
int* a = (int*)malloc(sizeof(int) * (n + 1));
memset(a, 0, sizeof(int) * (n + 1));
NODE* pHead = p, * q;
a[p->data > 0 ? p->data : -p->data] = 1;
while (p->link != NULL && p->link->data != INT_MIN) {
int t = (p->link->data) > 0 ? p->link->data : -p->link->data;
if (a[t] == 1) {
q = p->link;
p->link = q->link;
free(q);
}
else {
a[t] = 1;
p = p->link;
}
}
}
int main() {
int a[] = { -5,5,9,17,5,5,5,-3,2,5 };
NODE pStart;
create(&pStart, a, 0, 10);
deleteNode(&pStart, 100, 10);
return 0;
}