Advertisement
madalinaradu

IA adancime limitata

May 30th, 2019
104
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 4.11 KB | None | 0 0
  1. int adancimeLimitata(int start, int stop, int A[20][20], char *nume[20], int limita) {
  2.  
  3.     int nrNoduri = 0, contorViz = 0;
  4.  
  5.     int noduri[20];//orasele in asteptare
  6.     int viz[20];//orase deja vizitate
  7.     int parinte[20];//parinte[i]=j =>j este parintele lui i
  8.     int gasit = 0;
  9.     for (int i = 0; i < 20; i++)
  10.         viz[i] = 0;
  11.     viz[start] = 1;
  12.     noduri[0] = start;
  13.     nrNoduri++;
  14.     int contorpas = 0;
  15.  
  16.     cout << "Pasul " << contorpas++ << ": ";
  17.     for (int i = 0; i < nrNoduri; i++)
  18.         cout << nume[noduri[i]] << " ";
  19.     cout << endl;
  20.     int adancime[20];
  21.     adancime[start]=0;
  22.  
  23.  
  24.     while (gasit == 0 && nrNoduri > 0) {
  25.         int nod = noduri[0];
  26.         for (int i = 0; i < nrNoduri - 1; i++)
  27.             noduri[i] = noduri[i + 1];
  28.         nrNoduri--;
  29.         if (nod == stop)
  30.             gasit = 1;
  31.         else
  32.             for (int i = 0; i<20; i++)
  33.                 if ((A[nod][i] != 0) && (viz[i] == 0) && adancime[nod]<limita-1) {
  34.                     for (int j = nrNoduri-1; j >= 0; j--)
  35.                         noduri[j+1] = noduri[j];
  36.                     nrNoduri++;
  37.                     noduri[0] = i;
  38.                     viz[i] = 1;
  39.                     parinte[i] = nod;
  40.                     adancime[i]=adancime[nod]+1;
  41.                 }
  42.         cout << "Pasul " << contorpas++ << ": ";
  43.         for (int i = 0; i < nrNoduri; i++) {
  44.             cout << nume[noduri[i]] << " ";
  45.         }
  46.         cout << endl;
  47.     }
  48.  
  49.     if(gasit) {
  50.         cout << endl;
  51.         int temp = stop;
  52.         int contorTraseu = 0;
  53.         int traseu[20];
  54.         while (parinte[temp] != start) {
  55.             traseu[contorTraseu++] = temp;
  56.             temp = parinte[temp];
  57.         }
  58.         traseu[contorTraseu++] = temp;
  59.         traseu[contorTraseu++] = parinte[temp];
  60.         for (int i = contorTraseu - 1; i >= 0; i--) {
  61.             cout<<nume[traseu[i]]<<" "<<adancime[traseu[i]] <<", ";
  62.         }
  63.     } else
  64.         cout<<"nu  s-a gasit drum de la  "<<nume[start]<<" la  " <<nume[stop]<<"cu limita  "<<limita<<endl;
  65.     return 0;
  66. }
  67.  
  68. int H[20];
  69. int CreareMatrice(int A[20][20]) {
  70.  
  71.     A[0][1] = 75;
  72.     A[1][0] = 75;
  73.  
  74.     A[0][2] = 140;
  75.     A[2][0] = 140;
  76.  
  77.     A[0][3] = 118;
  78.     A[3][0] = 118;
  79.  
  80.     A[1][4] = 71;
  81.     A[4][1] = 71;
  82.  
  83.     A[4][2] = 151;
  84.     A[2][4] = 151;
  85.  
  86.     A[3][7] = 111;
  87.     A[7][3] = 111;
  88.  
  89.     A[7][10] = 70;
  90.     A[10][7] = 70;
  91.  
  92.     A[10][11] = 75;
  93.     A[11][10] = 75;
  94.  
  95.     A[11][12] = 120;
  96.     A[12][11] = 120;
  97.  
  98.     A[2][5] = 99;
  99.     A[5][2] = 99;
  100.  
  101.     A[2][6] = 80;
  102.     A[6][2] = 80;
  103.  
  104.     A[6][12] = 146;
  105.     A[12][6] = 146;
  106.  
  107.     A[6][9] = 97;
  108.     A[9][6] = 97;
  109.  
  110.     A[12][9] = 138;
  111.     A[9][12] = 138;
  112.  
  113.     A[5][8] = 211;
  114.     A[8][5] = 211;
  115.  
  116.     A[9][8] = 101;
  117.     A[8][9] = 101;
  118.  
  119.     A[8][13] = 90;
  120.     A[13][8] = 90;
  121.  
  122.     A[8][14] = 85;
  123.     A[14][8] = 85;
  124.  
  125.     A[14][15] = 98;
  126.     A[15][14] = 98;
  127.  
  128.     A[15][16] = 86;
  129.     A[16][15] = 86;
  130.  
  131.     A[14][17] = 142;
  132.     A[17][14] = 142;
  133.  
  134.     A[17][18] = 92;
  135.     A[18][17] = 92;
  136.  
  137.     A[18][19] = 87;
  138.     A[19][18] = 87;
  139.  
  140.  
  141.     return 0;
  142. }
  143.  
  144. int main() {
  145.     char *nume[20] = { "Arad", "Zerind", "Sibiu", "Timisoara", "Oradea", "Fagaras", "Ramnicu Valcea", "Lugoj", "Bucuresti", "Pitesti", "Mehadia", "Drobeta", "Craiova", "Giurgiu", "Urziceni", "Hirsova", "Eforie", "Vaslui", "Iasi", "Neamt" };
  146.     //                   0         1        2          3          4          5              6            7          8           9         10          11        12         13         14          15         16        17       18      19
  147.     for(int i=0; i<20; i++)}
  148.         for(j=0; j<20; j++){
  149.             A[i][j]=0;
  150.         }
  151.         }
  152.  
  153.  
  154.     CreareMatrice(A);
  155.     for(int i=0;i<20;i++){
  156.         for(int j=i+1;j<20;j++){
  157.             if(A[i][j]!=0){
  158.                 printf("%5d%5d%5d\n",i,j,A[i][j]);
  159.             }
  160.         }
  161.     }
  162.     cout<<"-----------"<<endl;
  163.     CreareVector(H);
  164.     int start = 0, stop = 8;
  165.     cout << endl << endl<< "Cautare in adancime limitata:" << endl;
  166.     adancimeLimitata(start,stop,A,nume,4);
  167.  
  168.     _getch();
  169.     return 0;
  170. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement