X-Git-Url: http://svarog.pmf.uns.ac.rs/gitweb/?p=spa2-materijali.git;a=blobdiff_plain;f=PretrazivanjeSaVracanjem%2FLavirint%2FSuperKomplikovanoResenje%2FMapa.java;fp=PretrazivanjeSaVracanjem%2FLavirint%2FSuperKomplikovanoResenje%2FMapa.java;h=a156601b92ae2392b1ee89826cfcdf1612f0f0fd;hp=091f37d8f8144fd353e663b0170d9ecf75ebcf97;hb=3f17bcf9a9707819b583e7940611c49185011ae7;hpb=950dc9f4ad875f11642668728d7c9493b5c9fe73 diff --git a/PretrazivanjeSaVracanjem/Lavirint/SuperKomplikovanoResenje/Mapa.java b/PretrazivanjeSaVracanjem/Lavirint/SuperKomplikovanoResenje/Mapa.java index 091f37d..a156601 100644 --- a/PretrazivanjeSaVracanjem/Lavirint/SuperKomplikovanoResenje/Mapa.java +++ b/PretrazivanjeSaVracanjem/Lavirint/SuperKomplikovanoResenje/Mapa.java @@ -1,95 +1,94 @@ - /** * Klasa Mapa koristi se za reprezentaciju lavirint i njegovih polja. */ public class Mapa { - // Vrednosti polja i njihova znacenja - public final static int IZLAZ = -5; - public final static int ZID = -1; - public final static int GRESKA = Integer.MIN_VALUE; + // Vrednosti polja i njihova znacenja + public final static int IZLAZ = -5; + public final static int ZID = -1; + public final static int GRESKA = Integer.MIN_VALUE; + + // Dimenzije mape + private int visina, sirina; + + // Polja mape + private int[][] mat; - // Dimenzije mape - private int visina, sirina; - - // Polja mape - private int[][] mat; + // Prilikom pretrazivanja ovde mozemo pamtiti koja polja smo posetili a koja nismo + private boolean[][] pos; - // Prilikom pretrazivanja ovde mozemo pamtiti koja polja smo posetili a koja nismo - private boolean[][] pos; + public int getSirina() { + return sirina; + } - public int getSirina() { - return sirina; - } + public int getVisina() { + return visina; + } - public int getVisina() { - return visina; - } + public void setPos(int x, int y, boolean b) { + if (0 <= x && x < sirina && 0 <= y && y < visina) { + pos[x][y] = b; + } + } - public void setPos(int x, int y, boolean b) { - if (0 <= x && x < sirina && 0 <= y && y < visina) { - pos[x][y] = b; - } - } + public boolean getPos(int x, int y) { + if (0 <= x && x < sirina && 0 <= y && y < visina) { + return pos[x][y]; + } else { + return true; + } + } - public boolean getPos(int x, int y) { - if (0 <= x && x < sirina && 0 <= y && y < visina) { - return pos[x][y]; - } else { - return true; - } - } + public int getMat(int x, int y) { + if (0 <= x && x < sirina && 0 <= y && y < visina) { + return mat[x][y]; + } else { + return GRESKA; + } + } - public int getMat(int x, int y) { - if (0 <= x && x < sirina && 0 <= y && y < visina) { - return mat[x][y]; - } else { - return GRESKA; - } - } + public Mapa(int sirina, int visina) { + this.sirina = sirina; + this.visina = visina; + mat = new int[sirina][visina]; + pos = new boolean[sirina][visina]; + } - public Mapa(int sirina, int visina) { - this.sirina = sirina; - this.visina = visina; - mat = new int[sirina][visina]; - pos = new boolean[sirina][visina]; - } + public Mapa(String imeFajla) { + if (!Svetovid.testIn(imeFajla)) { + throw new RuntimeException("Fajl za kreiranje mape (" + imeFajla + ") nije prisupacan"); + } + sirina = Svetovid.in(imeFajla).readInt(); + visina = Svetovid.in(imeFajla).readInt(); + mat = new int[sirina][visina]; + pos = new boolean[sirina][visina]; + for (int j = 0; j < visina; j++) { + for (int i = 0; i < sirina; i++) { + mat[i][j] = Svetovid.in(imeFajla).readInt(); + } + } + Svetovid.closeIn(imeFajla); + Prikaz.boja(ZID, Prikaz.CRNA, null); + Prikaz.boja(IZLAZ, Prikaz.CRVENA, Prikaz.BELA); + Prikaz.boja(1, 20, Prikaz.SVETLO_ZELENA, Prikaz.ZELENA, Prikaz.CRNA); + Prikaz.boja(99, Prikaz.ZUTA, Prikaz.CRNA); + Prikaz.mapa("Lavirint", getSirina(), getVisina(), this::getMat); + } - public Mapa(String imeFajla) { - if (!Svetovid.testIn(imeFajla)) { - throw new RuntimeException("Fajl za kreiranje mape (" + imeFajla + ") nije prisupacan"); - } - sirina = Svetovid.in(imeFajla).readInt(); - visina = Svetovid.in(imeFajla).readInt(); - mat = new int[sirina][visina]; - pos = new boolean[sirina][visina]; - for (int j = 0; j < visina; j++) { - for (int i = 0; i < sirina; i++) { - mat[i][j] = Svetovid.in(imeFajla).readInt(); - } - } - Svetovid.closeIn(imeFajla); - Prikaz.boja(ZID, Prikaz.CRNA, null); - Prikaz.boja(IZLAZ, Prikaz.CRVENA, Prikaz.BELA); - Prikaz.boja(1, 20, Prikaz.SVETLO_ZELENA, Prikaz.ZELENA, Prikaz.CRNA); - Prikaz.boja(99, Prikaz.ZUTA, Prikaz.CRNA); - Prikaz.mapa("Lavirint", getSirina(), getVisina(), this::getMat); - } + public void stampaj() { + if (visina != 0 && sirina != 0) { + System.out.println(); + System.out.println("Mapa sirine " + sirina + " i visine " + visina); + for (int j = 0; j < visina; j++) { + for (int i = 0; i < sirina; i++) { + System.out.printf("%5d", mat[i][j]); + } + System.out.println(); + } + } + } - public void stampaj() { - if (visina != 0 && sirina != 0) { - System.out.println(); - System.out.println("Mapa sirine " + sirina + " i visine " + visina); - for (int j = 0; j < visina; j++) { - for (int i = 0; i < sirina; i++) { - System.out.printf("%5d", mat[i][j]); - } - System.out.println(); - } - } - } - - public String toString() { - return "Mapa velicine " + sirina + " x " + visina; - } + public String toString() { + return "Mapa velicine " + sirina + " x " + visina; + } }