Sha256: f6defefb3ed782d91530b4e57281b83833afdf1c5f332449be7dde8e61493f12

Contents?: true

Size: 1.99 KB

Versions: 14

Compression:

Stored size: 1.99 KB

Contents

/*
Copyright 2007, 2008 Daniel Zerbino (zerbino@ebi.ac.uk)

    This file is part of Velvet.

    Velvet is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 2 of the License, or
    (at your option) any later version.

    Velvet is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with Velvet; if not, write to the Free Software
    Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA

*/
#include <stdlib.h>

#include "fib.h"
#include "utility.h"

// Constructor
// Memory allocated
FibHeap *newFibHeap()
{
	FibHeap * heap = fh_makekeyheap();
	if (heap == NULL)
		exitErrorf(EXIT_FAILURE, true, "Can't allocate FibHeap");
	
	return heap;
}

// Add new node into heap with a key, and a pointer to the specified node
FibHeapNode *insertNodeIntoHeap(FibHeap * heap, Coordinate key,
				struct node_st * node)
{
	return fh_insertkey(heap, key, node);
}

// Returns smallest key in heap
Coordinate minKeyOfHeap(FibHeap * heap)
{
	return fh_minkey(heap);
}

// Replaces the key for a given node
Coordinate replaceKeyInHeap(FibHeap * heap, FibHeapNode * node,
			    Coordinate newKey)
{
	return fh_replacekey(heap, node, newKey);
}

// Removes the node with the shortest key, then returns it.
struct node_st *removeNextNodeFromHeap(FibHeap * heap)
{
	return (struct node_st *) fh_extractmin(heap);
}

// Destructor
void destroyHeap(FibHeap * heap)
{
	fh_deleteheap(heap);
}

// Replace the node pointed to by a heap node
void replaceValueInHeap(FibHeapNode * node, Node * newValue)
{
	fh_replacedata(node, newValue);
}

// Remove unwanted node
void destroyNodeInHeap(FibHeapNode * node, FibHeap * heap)
{
	fh_delete(heap, node);
}

Version data entries

14 entries across 14 versions & 2 rubygems

Version Path
finishm-0.0.9 ext/src/src/fibHeap.c
bio-velvet_underground-0.3.1 ext/src/src/fibHeap.c
finishm-0.0.8 ext/src/src/fibHeap.c
finishm-0.0.7 ext/src/src/fibHeap.c
finishm-0.0.6 ext/src/src/fibHeap.c
finishm-0.0.5 ext/src/src/fibHeap.c
finishm-0.0.4 ext/src/src/fibHeap.c
finishm-0.0.2 ext/src/src/fibHeap.c
finishm-0.0.1 ext/src/src/fibHeap.c
bio-velvet_underground-0.3.0 ext/src/src/fibHeap.c
bio-velvet_underground-0.2.1 ext/src/src/fibHeap.c
bio-velvet_underground-0.2.0 ext/src/src/fibHeap.c
bio-velvet_underground-0.1.0 ext/src/src/fibHeap.c
bio-velvet_underground-0.0.1 ext/src/src/fibHeap.c