Advertisement
Filip13

dfs - lavirint

May 22nd, 2024
593
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C# 2.33 KB | Source Code | 0 0
  1. namespace dfs___lavirint
  2. {
  3.     internal class Program
  4.     {
  5.         static void Main(string[] args)
  6.         {
  7.             int[,] polja = new int[,]
  8.             {
  9.                 {0, 0, 0, 0, 0 },
  10.                 {0, 0, -1, -1, -1 },
  11.                 {0, 0, -1, -1, 0 },
  12.                 {0, 0, 0, 0, 0 },
  13.             };
  14.  
  15.             int brojKolonaMatrice = polja.GetLength(1);
  16.             Stack<int> poljaZaObilazak = new();
  17.             int brojacPoteza = 1;
  18.  
  19.             poljaZaObilazak.Push(0);
  20.  
  21.             int[,] validniPotezi =
  22.             {
  23.                 { 0, 1 },   //desno
  24.                 { 1, 0 },   //dole
  25.                 { 0, -1 },  //levo
  26.                 { -1, 0 },  //gore
  27.             };
  28.  
  29.             while (poljaZaObilazak.Any())
  30.             {
  31.                 int pozicijaPolja = poljaZaObilazak.Pop();
  32.  
  33.                 int redPolja = pozicijaPolja / brojKolonaMatrice;
  34.                 int kolonaPolja = pozicijaPolja % brojKolonaMatrice;
  35.  
  36.                 polja[redPolja, kolonaPolja] = brojacPoteza;
  37.                 brojacPoteza++;
  38.  
  39.                 Console.WriteLine($"obilazak polja {pozicijaPolja} - ({redPolja},{kolonaPolja})");
  40.  
  41.                 for (int i = 0; i < validniPotezi.GetLength(0); i++)
  42.                 {
  43.                     int noviRed = redPolja + validniPotezi[i, 0];//i je cela "zagrada" u validniPotezi, a 0 ce dati red
  44.                     int novaKolona = kolonaPolja + validniPotezi[i, 1];                              // a 1 ce dati kolonu
  45.  
  46.                     if (noviRed >= 0 && noviRed < polja.GetLength(0) && novaKolona >= 0 && novaKolona < polja.GetLength(1) && polja[noviRed, novaKolona] == 0)
  47.                     {
  48.                         int novaPozicija = noviRed * brojKolonaMatrice + novaKolona;
  49.                         poljaZaObilazak.Push(novaPozicija);
  50.  
  51.                         polja[noviRed, novaKolona] = -10  ;
  52.                     }
  53.                 }
  54.             }
  55.  
  56.             IspisisMatricu(polja);
  57.         }
  58.  
  59.         static void IspisisMatricu(int[,] polja)
  60.         {
  61.             for (int i = 0; i < polja.GetLength(0); i++)
  62.             {
  63.                 for (int j = 0; j < polja.GetLength(1); j++)
  64.                 {
  65.                     Console.Write($"{polja[i, j]}\t");
  66.                 }
  67.                 Console.WriteLine();
  68.             }
  69.         }
  70.  
  71.     }
  72. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement