Advertisement
Raizekas

Untitled

Dec 13th, 2015
174
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C# 3.09 KB | None | 0 0
  1.    static void Patikrinti(Plotai sodas, int x, int y, ref List<List<int>> tikrinamasTaskas)
  2.         {        
  3.             for (int i = x-1; i < x+1; i++)
  4.             {
  5.                 for(int j=y-1; j<y+1; j++)
  6.                 {
  7.                     if (i <= 0 && j <= 0 && i > sodas.nn && j > sodas.mm)
  8.                     {
  9.                         if (sodas.Imti(i, j) == '*' && i != x && j != y)
  10.                         {
  11.                             bool arYraTaskas = false;
  12.                             List<int> sublistas = new List<int>();
  13.                             for (int k = 0; k < tikrinamasTaskas.Count; k++)
  14.                             {
  15.                                 if (tikrinamasTaskas[k].Contains(i) && tikrinamasTaskas[k].Contains(j))
  16.                                     arYraTaskas = true;
  17.                             }
  18.                             if (!arYraTaskas)
  19.                             {
  20.                                 sublistas.Add(i);
  21.                                 sublistas.Add(j);
  22.                                 tikrinamasTaskas.Add(sublistas);
  23.                             }
  24.                         }
  25.                     }
  26.                 }
  27.             }
  28.         }
  29.         static void ArLangeliaiNuspalvinti(Plotai sodas)
  30.         {
  31.             int ilgiausiosDemesIlgis = 0;
  32.            
  33.             for (int i=0; i<sodas.nn; i++)    // eini per kiekvieną langelį; i - "ciklo kintamasis"
  34.             {
  35.                 for(int j=0; j<sodas.mm; j++)
  36.                 {
  37.                     List<List<int>> tikrinamiLangeliai = new List<List<int>>();
  38.                     List<int> sublist = new List<int>();
  39.                         // tikrinamiLangeliai - šiuo metu tikrinamų langelių sąrašas
  40.                     if (sodas.Imti(i, j) == '*')
  41.                     {
  42.                         sublist.Add(i);
  43.                         sublist.Add(j);
  44.  
  45.                         tikrinamiLangeliai.Add(sublist);
  46.                     }      // kad kai einam per visus langelius, bent tą langelį (jei jis nuspalvintas), ant kurio dabar "užėjom" patikrintų
  47.                         for (int jj=0; jj<tikrinamiLangeliai.Count; jj++)       // eiti per visus langelius, kuriuos reikės tikrint (pastabaa: tikrinant langelius, gali atsirasti dar naujų tikrinamiLangeliai, . ciklo kintamasis j
  48.                         {
  49.                             Patikrinti(sodas, i, j, ref tikrinamiLangeliai);
  50.                                 // Jeigu tikrinamasis langelis turėjo kokių langelių, kurie tiko, juos reikės pridėti prie tikrinamiLangeliai list'o (greičiausiai tai implementuoti geriausia Patikrinti methode (nebūtinai))
  51.                         }
  52.                        if (tikrinamiLangeliai.Count > ilgiausiosDemesIlgis)
  53.                         {
  54.                             ilgiausiosDemesIlgis = tikrinamiLangeliai.Count;
  55.                         }
  56.                         //Jei didžiausia dėmė: atsiminti dėmės ilgį, atsiminti visilangeliai[i] vietą (kadangi reikia bent vieną dėmės tašką išvesti)
  57.                     }
  58.              }
  59.         }
  60.     }
  61. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement