#include <stdio.h>
#include <stdlib.h>
struct Node {
int val;
struct Node *next;
struct Node *random;
};
static struct Node *copyRandomList(struct Node *head)
{
struct Node *p, *q;
/* insert interleavingly */
for (p = head; p != NULL; p = q->next) {
q = malloc(sizeof(*q));
q->val = p->val;
q->next = p->next;
p->next = q;
}
/* clone random pointer */
for (p = head; p != NULL; p = q->next) {
q = p->next;
q->random = p->random != NULL ? p->random->next : NULL;
}
struct Node dummy;
struct Node *prev = &dummy;
prev->next = head;
/* separate q list */
for (p = head; p != NULL; p = q->next) {
q = p->next;
/* restore p->next */
p->next = q->next;
prev->next = q;
prev = q;
}
/* q->next = NULL */
return dummy.next;
}
int main(int argc, char **argv)
{
int i, count = argc - 1;
struct Node *head = NULL, *p, *prev;
for (i = 0; i < count; i++) {
p = malloc(sizeof(*p));
p->val = atoi(argv[i + 1]);
p->next = NULL;
p->random = NULL;
if (head == NULL) {
head = p;
} else {
prev->next = p;
prev->random = p;
}
prev = p;
}
struct Node *r = head;
struct Node *q = p = copyRandomList(head);
for (r = head; r != NULL; r = r->next) {
printf("%d ", r->val);
}
printf("\n");
for (r = head; r != NULL; r = r->random) {
printf("%d ", r->val);
}
printf("\n");
for (; p != NULL; p = p->next) {
printf("%d ", p->val);
}
printf("\n");
for (; q != NULL; q = q->random) {
printf("%d ", q->val);
}
printf("\n");
return 0;
}

Ddddddd_158
- 粉丝: 3167
最新资源
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈


