directgraph.h

#include<stdio.h>

#include<stdlib.h>

#include"jval.h"

#include"jrb.h"

#include"dllist.h"

#define gray 1

#define white 0

#define black 2

#define MAX 10

#define limited 999.0

typedef struct _key

{

int visited;

int id;

int indegree;

int known;

double d;

struct _key *p;

}key;

typedef struct

{

JRB edges;

JRB vertices;

int maxvertices;

}Graph;

Graph creatgraph(Graph graph);

int compare(Jval a,Jval b);

Jval makekey(int id);

int addvertex(Graph *graph,char *name);

//tra ve id co ten name

int getID(Graph *graph,char *name);

//kiem tra co ton tai id khong

int existid(Graph *graph,int id);

void addEdge(Graph *graph,int v1,int v2,double trongso);

//return name of id

char * getvertex(Graph *graph,int id);

//Kiem tra co ton tai name khong

int existname(Graph *graph,char *name);

//kiem tra co canh noi giua v1 voi v2 khong

int hasedge(Graph *graph,int v1,int v2);

//tra ve bac ra cua dinh v

//cac dinh duoc luu trong output

int outdegree(Graph *graph,int v,int *output);

//tra ve bac vao cua dinh v

//cac dinh duoc luu trong output

int indegree(Graph *graph,int v,int *output);

void freegraph(Graph graph);

//Duyet do thi theo BFS

//ham func thuc hien chuc nang tai moi node cua do thi

void BFS (Graph *graph,int s,void (*func)(int,Graph *));

//Duyet do thi theo DFS

void DFS (Graph *graph,int s,void (*func)(int,Graph *));

//Dao nguoc do thi

Graph reversegraph(Graph *graph);

//sap xep Topo,in ra 1 thu tu Topo

void Tsort(Graph *graph,void (*func)(int,Graph *));

//Duong di ngan nhat khi khong co trong so

void shortestpath(Graph *graph,int u,int v);

//List all the way from goc to v

//khi truyen tham so trong chuong trinh chinh thi s = goc,v la id dinh den

void DFSrecusivelt(Graph *graph,int goc,int s,int v);

double trongso(Graph *graph,int u,int v);//return weight of (u->v)

//DIJKSTRA

void Dijkstra(Graph *graph,int s);

//Kiem tra co chu trinh ko,neu co in ra cac chu trinh

void cycledetecting(Graph *graph,int *dem);

//Tra ve so thanh phan lien thong

int checklienthong(Graph *graph);

Bạn đang đọc truyện trên: AzTruyen.Top

Tags: #hongson