summaryrefslogtreecommitdiffstats
path: root/src/random_heuristic.c
diff options
context:
space:
mode:
authorAlexandre Jesus <adbjesus@gmail.com>2016-09-23 09:34:49 +0100
committerAlexandre Jesus <adbjesus@gmail.com>2016-09-23 09:34:49 +0100
commit6c620091ec068c31e4ed5e7e480b5abdd2329b0f (patch)
tree74e1de882b838c0da5f08cf32aaa46a9993ed25f /src/random_heuristic.c
parent7963cc3c89b8c03a073d17f58833ad191a3903a9 (diff)
downloadlibuknapsack-6c620091ec068c31e4ed5e7e480b5abdd2329b0f.tar.gz
libuknapsack-6c620091ec068c31e4ed5e7e480b5abdd2329b0f.zip
Add random heuristic method
Diffstat (limited to 'src/random_heuristic.c')
-rw-r--r--src/random_heuristic.c82
1 files changed, 80 insertions, 2 deletions
diff --git a/src/random_heuristic.c b/src/random_heuristic.c
index 4e3e47f..bd3efa5 100644
--- a/src/random_heuristic.c
+++ b/src/random_heuristic.c
@@ -3,7 +3,85 @@
#include "structs.h"
#include "common.h"
-struct front_item * random_heuristic(struct data * d) {
-
+struct front_item * random_heuristic(struct data * data) {
+ struct front_item * front = new_front_item(0, 0, NULL, NULL);
+ struct front_item * front_last = front;
+ struct tree_item * tree = new_tree_item(0, 0, 0, 0, NULL, NULL);
+ long int tree_size = 1;
+
+ do {
+ /* Choose tree node randomly */
+ long int position = rand() % tree_size;
+ struct tree_item * node = tree;
+ for(int i = 0; i < position; i++,node=node->next);
+
+ /* Check if node is leaf */
+ if(node->depth == data->N) {
+ front_last->next = new_front_item(node->values.p, node->values.w, front_last, NULL);
+ front_last = front_last->next;
+
+ struct tree_item * old = node;
+ if(tree == old) {
+ tree = node->next;
+ }
+
+ if(node->next != NULL) {
+ node->next->prev = node->prev;
+ }
+ if(node->prev != NULL) {
+ node->prev->next = node->next;
+ }
+ free(old);
+ /* Reduce tree_size */
+ tree_size--;
+
+ continue;
+ }
+
+ /* Make left node (select item) */
+ struct tree_item * left = new_tree_item(
+ node->depth + 1,
+ node->itemi + 1,
+ node->values.w + data->items[node->itemi].w,
+ node->values.p + data->items[node->itemi].p,
+ node->prev,
+ node
+ );
+ if(node->prev != NULL){
+ node->prev->next = left;
+ }
+
+ /* Make right node (do not select item) */
+ struct tree_item * right = new_tree_item(
+ node->depth + 1,
+ node->itemi + 1,
+ node->values.w,
+ node->values.p,
+ left,
+ node->next
+ );
+ if(node->next != NULL) {
+ node->next->prev = right;
+ }
+
+ /* Adjust left->next to right */
+ left->next = right;
+
+ struct tree_item * old = node;
+ if(node == tree) {
+ tree = left;
+ }
+ free(old);
+
+ /* Increment tree_size */
+ tree_size++;
+ } while(tree != NULL);
+
+ /* Remove first item from front (only a placeholder) */
+ front=front->next;
+ free(front->prev);
+ front->prev = NULL;
+
+ return front;
return NULL;
}