Skip to content

Commit

Permalink
Partition list
Browse files Browse the repository at this point in the history
Signed-off-by: begeekmyfriend <[email protected]>
  • Loading branch information
begeekmyfriend committed Sep 15, 2017
1 parent 38698bf commit aac33db
Show file tree
Hide file tree
Showing 2 changed files with 66 additions and 0 deletions.
2 changes: 2 additions & 0 deletions 086_partition_list/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
all:
gcc -O2 -o test partition_list.c
64 changes: 64 additions & 0 deletions 086_partition_list/partition_list.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
#include <stdio.h>
#include <stdlib.h>

struct ListNode {
int val;
struct ListNode *next;
};

struct ListNode* partition(struct ListNode* head, int x) {
struct ListNode dummy;
struct ListNode *p = NULL, *start = &dummy, *pivot;
dummy.next = head;
for (pivot = head; pivot != NULL; pivot = pivot->next) {
if (pivot->val >= x) {
break;
}
start = pivot;
}

struct ListNode *prev;
for (p = pivot; p != NULL; p = p->next) {
if (p->val < x) {
prev->next = p->next;
p->next = start->next;
start->next = p;
start = p;
p = prev;
}
prev = p;
}
return dummy.next;
}

int main(int argc, char **argv)
{
if (argc < 2) {
fprintf(stderr, "Usage: ./test target n1 n2 n3...\n");
exit(-1);
}

int i, target = atoi(argv[1]);
struct ListNode *head = NULL;
struct ListNode *prev = NULL;
struct ListNode *p;
for (i = 0; i < argc - 2; i++) {
p = malloc(sizeof(*p));
p->val = atoi(argv[i + 2]);
p->next = NULL;
if (head == NULL) {
head = p;
prev = head;
} else {
prev->next = p;
prev = p;
}
}
p = partition(head, target);
while (p != NULL) {
printf("%d ", p->val);
p = p->next;
}
printf("\n");
return 0;
}

0 comments on commit aac33db

Please sign in to comment.