Advertisement
Guest User

Untitled

a guest
Jan 18th, 2017
83
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 2.16 KB | None | 0 0
  1. #include <stdio.h>
  2. #include <string.h>
  3.  
  4. #define N_MAX 75
  5. int i[N_MAX], j[N_MAX];
  6.  
  7. int is_final(int i[], int j[], int pos, int N) {
  8.  
  9. if (i[pos] == N - 1 && j[pos] == N - 1)
  10. {
  11. return 1;
  12. }else
  13. return 0;
  14. }
  15.  
  16.  
  17. int has_been_visited(int i[], int j[], int line, int col, int pos) {
  18.  
  19. for (int k = 0; k < pos; ++k)
  20. {
  21. if (i[pos-1] == line && j[pos-1] == col)
  22. return 1;
  23. else
  24. return 0;
  25. }
  26.  
  27. }
  28.  
  29. int soma(int i[], int j[], int pos, int m[][N_MAX]) {
  30.  
  31. int sum = 0, line, row;
  32.  
  33. for (int k = 0; k <= pos; ++k)
  34. {
  35. line = i[k];
  36. row = j[k];
  37. sum += m[line][row];
  38. }
  39.  
  40. //printf("soma: %d\n", sum);
  41.  
  42. return sum;
  43. }
  44.  
  45. int neg(int i[], int j[], int pos, int m[][N_MAX]) {
  46. int neg = 0, line, row;
  47.  
  48. for (int k = 0; k <= pos; ++k)
  49. {
  50. line = i[k];
  51. row = j[k];
  52. if (m[line][row] < 0)
  53. {
  54. neg++;
  55. }
  56. }
  57.  
  58. //printf("negativos: %d\n", neg);
  59. return neg;
  60. }
  61.  
  62. void verifica(){
  63.  
  64. }
  65.  
  66. void move(int i[], int j[], int pos, int n, int m[][N_MAX]) {
  67. int line = i[pos];
  68. int col = j[pos];
  69.  
  70.  
  71.  
  72. if (is_final(i, j, pos, n)) {
  73. printf("Caminho encontrado:");
  74.  
  75. soma(i,j,pos,m);
  76. neg(i,j,pos,m);
  77.  
  78. int max = 0;
  79. for (int k = 0; k <= pos; ++k)
  80. {
  81.  
  82. printf(" -> [%d,%d]", i[k]+1, j[k]+1);
  83. }
  84. printf("\n");
  85. return;
  86. }
  87.  
  88. if (line + 1 < n && !(has_been_visited(i, j, line+1, col, pos)))
  89. {
  90. // Down
  91. i[pos+1] = line + 1;
  92. j[pos+1] = col;
  93. move(i,j,pos+1,n,m);
  94. }
  95.  
  96. if (col+ 1 < n && !(has_been_visited(i, j, line, col+1, pos)))
  97. {
  98. // Right
  99. j[pos+1] = col + 1;
  100. i[pos+1] = line;
  101. move(i,j,pos+1,n,m);
  102. }
  103.  
  104. if (col - 1 >= 0 && !(has_been_visited(i, j, line, col-1, pos)))
  105. {
  106. // Left
  107. i[pos+1] = line;
  108. j[pos+1] = col - 1;
  109. move(i,j,pos+1,n,m);
  110. }
  111.  
  112.  
  113. }
  114.  
  115.  
  116.  
  117. int main(int argc, char const *argv[])
  118. {
  119. int n;
  120. scanf("%d", &n);
  121. memset(i, 0, sizeof(int) * n);
  122. memset(j, 0, sizeof(int) * n);
  123.  
  124. int m[N_MAX][N_MAX];
  125.  
  126. for (int k = 0; k < n; ++k)
  127. {
  128. for (int l = 0; l < n; ++l)
  129. {
  130. m[k][l] = -2;
  131. }
  132. }
  133.  
  134. i[0] = 0;
  135. j[0] = 0;
  136.  
  137. move(i, j, 0, n, m);
  138.  
  139. return 0;
  140. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement