ADT Graph Disusun untuk Memenuhi Laporan Praktikum Algoritma dan Struktur Data
Oleh: Nama
: Sukarjo
NIM
: 115090613111001
Hari/Tanggal
: Selasa/18 Desember 2012
Asisten: 1. Dwy Saputro 2. Ilham Yuliantoro
LABORATORIUM KOMPUTER DASAR PROGRAM STUDI ILMU KOMPUTER PROGRAM TEKNOLOGI INFORMASI DAN ILMU KOMPUTER UNIVERSITAS BRAWIJAYA MALANG 2012
Dasar Teori
Suatu graph adalah pasangan g = (V,E) V adalah himpunan tidak kosong terbatas vertex dari G, dan E = VxV. Terdapat dua jenis graph yakni graph berarah dan graph tidak berarah. ADT graph dapat dipresentasikan dengan dua cara yakni adjacency matrik atau adjacenty list
Contoh gambar Graph, sumber google.com
Sourcode
Class Stack package Graph; class Stack { private final int SIZE = 20; private int[] st; private int top; public Stack() { st = new int[SIZE]; top = -1; }
public void push(int j) { st[++top] = j; } public int pop() { return st[top--]; } public int peek() { return st[top]; } public boolean isEmpty() { return (top == -1); } }
Class Queue package Graph; class Queue { private final int SIZE = 20; private int[] queArray; private int front; private int rear; public Queue() { queArray = new int[SIZE]; front = 0; rear = -1; } public void insert(int j) { if(rear == SIZE-1) rear = -1; queArray[++rear] = j; } public int remove() { int temp = queArray[front++]; if(front == SIZE) front = 0; return temp; } public boolean isEmpty() { return ( rear+1==front || (front+SIZE-1==rear) ); } } class Vertex { public char label; public boolean wasVisited;
public Vertex(char lab) { label = lab; wasVisited = false; } }
Class Graph package Graph; public class Graph { private final int MAX_VERTS = 20; private Vertex vertexList[]; private int adjMat[][]; private int nVerts; private Stack theStack; private Queue theQueue; public Graph() { vertexList = new Vertex[MAX_VERTS]; adjMat = new int[MAX_VERTS][MAX_VERTS]; nVerts = 0; for(int j=0; j<MAX_VERTS; j++) for(int k=0; k<MAX_VERTS; k++) adjMat[j][k] = 0; theStack = new Stack(); theQueue = new Queue(); } public void addVertex(char lab) { vertexList[nVerts++] = new Vertex(lab); } public void addEdge(int start, int end) { adjMat[start][end] = 1; adjMat[end][start] = 1; } public void displayVertex(int v) { System.out.print(vertexList[v].label); } public void dfs() { vertexList[0].wasVisited = true; displayVertex(0); theStack.push(0); while( !theStack.isEmpty() ) { int v = getAdjUnvisitedVertex( theStack.peek() ); if(v == -1)
theStack.pop(); else { vertexList[v].wasVisited = true; displayVertex(v); theStack.push(v); } } for(int j=0; j
public int getAdjUnvisitedVertex(int v) { for(int j=0; j
1); 2); 3); 4); 5);
Graph Gb=new Graph(); Gb.addVertex('A'); Gb.addVertex('B'); Gb.addVertex('C'); Gb.addVertex('D'); Gb.addVertex('E'); Gb.addVertex('F'); Gb.addEdge(0, Gb.addEdge(1, Gb.addEdge(0, Gb.addEdge(3, Gb.addEdge(3,
1); 2); 3); 4); 5);
Graph Gc=new Graph(); Gc.addVertex('A'); Gc.addVertex('B'); Gc.addVertex('C'); Gc.addVertex('D'); Gc.addVertex('E'); Gc.addVertex('F'); Gc.addEdge(0, Gc.addEdge(0, Gc.addEdge(0, Gc.addEdge(0, Gc.addEdge(0, Gc.addEdge(1, Gc.addEdge(1, Gc.addEdge(1, Gc.addEdge(1, Gc.addEdge(2, Gc.addEdge(2, Gc.addEdge(2, Gc.addEdge(3,
1); 2); 3); 4); 5); 2); 3); 4); 5); 3); 4); 5); 4);
Gc.addEdge(3, 5); Gc.addEdge(4, 5); System.out.print("Depth First Search\n"); System.out.print("==================\n"); Ga.dfs(); System.out.println("\n\n"); System.out.print("Breadth-First Search\n"); System.out.print("====================\n"); Gb.bfs(); System.out.println("\n\n"); System.out.print("Minimum Spanning Tree\n"); System.out.print("=====================\n"); Ga.mst(); } }
Output
Analisa class Stack ini adalah nama dari class Stack public Stack() ini ialah constructor class Queue ini adalah class dari Queue yang berfungsi untuk pengantrian dari inputan sebuah karakter yang dimasukan. public class Graph ini adalah kelas utama dari kelas Graph. public Graph() sebuah konstruktor dari class Graph. public void addVertex(char lab) argument dari sebuah label dari class vertex public void addEdge (int start, int end) sebuah method untuk edge start dan end public void displayVertex(int v) ini adalah method untuk tampilkan vertex public void dfs() ini adalah method dari dfs yang berfungsi untuk mencari dari nilai dfs public void mst() ini adalah method dari mst yang berfungsi untuk mencari dari nilai mst public int getAdjUnvisitedVertex(int v) ini adalah sebuah method dari vertex yang menghubungkan nilai-nilainya public static void main(String[] args) ini adalah sebuah method utama yang berfungsi untuk menampilkan semua jalan dari program diatas Ga.dfs(); ini untuk memanggil nilai dari dfs Gb.bfs(); ini untuk memanggil nilai dari bfs Ga.mst(); ini untuk memanggil nilai dari mst
Kesimpulan Kesimpulan dari praktikum ini ialah dapat mengerti sebuah program Graph dan disini dibahas juga method Stack yang sebelumnya sudah dibahas dalam bab 3, methoth Queue atau antrian yang sebelumnya dibahas dalam bab 7. Dan disini juga terdapat method vertex yang artinya sebuah simpul dari Graph.
Daftar Pustaka Drs. Achmad Ridok, M.Kom, Modul Praktikum Algoritma dan Struktur Data 1, 2012 http://www.google.co.id/imgres?q=algoritma+graph