/*
This program 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 3 of the License, or
(at your option) any later version.
This program 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 this program. If not, see
*/
#include
#include
#include
#include
#include"misc.h"
#include"LinkedList.h"
#include"MemoryManager.h"
#include"adjlist_algorithm.h"
/*! \file adjlist.c
\brief Execute the adjlist algorithm in adjlist_algorithm.c
and print the number of cliques found and wall clock
execution time.
\author Darren Strash (first name DOT last name AT gmail DOT com)
\copyright Copyright (c) 2011 Darren Strash. This code is released under the GNU Public License (GPL) 3.0.
\image html gplv3-127x51.png
\htmlonly
See GPL 3.0 here
\endhtmlonly
*/
int main()
{
#ifdef MEMORY_DEBUG
fprintf(stderr, "WARNING: MEMORY_DEBUG is defined, timing will be off.\n");
#endif
int n; // number of vertices
int m; // 2x number of edges
LinkedList** adjacencyList = readInGraphAdjList(&n,&m);
int i;
int** adjList = Calloc(n, sizeof(int*));
int* degree = Calloc(n, sizeof(int));
for(i=0;ihead->next;
while(!isTail(curr))
{
adjList[i][j++] = (int)(curr->data);
curr = curr->next;
}
}
#ifdef RETURN_CLIQUES_ONE_BY_ONE
LinkedList* cliques = createLinkedList();
#endif
runAndPrintStatsListList( &listAllMaximalCliquesAdjacencyList,
"tomita-adjacency-list",
adjacencyList, adjList,
#ifdef RETURN_CLIQUES_ONE_BY_ONE
cliques,
#endif
degree, n);
// Free up memory from adjacency list.
#ifdef RETURN_CLIQUES_ONE_BY_ONE
destroyCliqueResults(cliques);
#endif
i = 0;
while(i