Advertisement
Oppaceted

Untitled

Feb 26th, 2023
326
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1.  
  2. program x0
  3.     implicit none
  4.     !определение переменных и функций
  5.     character, allocatable :: table(:,:)
  6.     integer :: n,win,a,b,player
  7.     logical :: process
  8.     integer :: player_win
  9.     !тело программы
  10.     !
  11.     !проверка корректности введённых значений размера поля и количества клеток, необхожимых для выигрыша
  12.     do while(.true.)
  13.         write (*,'(a$)') 'Enter the size of the field:'
  14.         read (*,*) n
  15.         if ( (n >= 20) .or. (n <= 0) ) then
  16.             write (*,'(a)') 'Too big or incorrect value, try again.'
  17.             cycle
  18.         else
  19.             exit
  20.         end if
  21.     end do
  22.     do while(.true.)
  23.         write (*,'(a$)') 'Enter the number of cells required to win:'
  24.         read (*,*) win
  25.         if ( (win > n) .or. (win <= 0) ) then
  26.             write (*,'(a)') 'Too big or incorrect value, try again.'
  27.             cycle
  28.         else
  29.             exit
  30.         end if
  31.     end do
  32.     allocate(table(n,n))
  33.     table(:,:) = '-'
  34.     player = 1
  35.     process = .true.
  36.     !
  37.     do while(process)
  38.         !
  39.         !проверка выигрыша и заполненности таблицы - 1,2 - выигрыш
  40.         !соответствующих игроков, 3 - заполненность - 0 - игра продолжается
  41.         if (player_win(n,win,table)==1) then
  42.             write (*,'(a)') 'Congrats! Player 1 won!'
  43.             exit
  44.         elseif (player_win(n,win,table)==2) then
  45.             write (*,'(a)') 'Congrats! Player 2 won!'
  46.             exit
  47.         elseif (player_win(n,win,table)==3) then
  48.             write (*,'(a)') 'No one won!'
  49.             exit
  50.         else
  51.             do while (.true.)
  52.                 write (*,'(a,1x,i1,1x,a)') 'Player',player,'walks'
  53.                 write (*,'(a$)') 'Enter a row: '
  54.                 read (*,'(i5$)') a
  55.                 write (*,'(a$)') 'Enter a column: '
  56.                 read (*,'(i5$)') b
  57.                 if ( (.not.((a<=n).and.(1<=a))) .or. (.not.((b<=n).and.(1<=b))) ) then
  58.                     write (*,'(a)') 'Enter the correct value!'
  59.                     cycle
  60.                 else if  ( (table(a,b) == '0') .or. (table(a,b) == 'x') ) then
  61.                     write (*,'(a)') 'Enter the correct value!'
  62.                     cycle
  63.                 else
  64.                     exit
  65.                 end if
  66.             end do
  67.             if (player == 1) then
  68.                 table(a,b) = 'x'
  69.                 player = 2
  70.             else
  71.                 table(a,b) = '0'
  72.                 player = 1
  73.             end if
  74.             call draw(n,table)
  75.         end if
  76.     end do
  77.     deallocate(table)
  78. end program x0
  79. !
  80. !процедура отрисовки поля
  81. subroutine draw(draw_size,draw_table)
  82.     integer :: draw_size, dr_1, dr_2
  83.     character :: draw_table(draw_size,draw_size)
  84.     !
  85.     do dr_1 =1,draw_size
  86.         if (dr_1 /= draw_size) then
  87.             write (*,'(1x,i2$)') dr_1
  88.         else
  89.             write (*,'(1x,i2)') dr_1
  90.         end if
  91.     end do
  92.     do dr_1 =1,draw_size
  93.         do dr_2 =1,(draw_size-1)
  94.             write (*,'(2x,a$)') draw_table(dr_1,dr_2)
  95.         end do
  96.         write (*,'(2x,a,1x,i2)') draw_table(dr_1,draw_size), dr_1
  97.     end do
  98. end subroutine
  99. !
  100. !функция выигрыша (состоит из других функций и процедур)
  101. integer function player_win(pw_size, pw_win, pw_table)
  102.     integer :: pw_1, pw_2, pw_size, pw_win, cut_win
  103.     character :: pw_table(pw_size,pw_size), pw_win_table(pw_win,pw_win)
  104.     logical :: full
  105.     !
  106.     !
  107.     player_win = 0
  108.     if (full(pw_size, pw_table)) then
  109.         player_win = 3
  110.     end if
  111.     do pw_1 = 1, (pw_size-pw_win+1)
  112.         do pw_2 = 1, (pw_size-pw_win+1)
  113.             call equate(pw_size,pw_win,pw_table,pw_win_table,pw_1,pw_2)
  114.             if (cut_win(pw_win, pw_win_table) /= 0) then
  115.                 player_win = cut_win(pw_win, pw_win_table)
  116.                 return
  117.             end if
  118.         end do
  119.     end do
  120. end function
  121. !
  122. !функция проверки заполненности поля
  123. logical function full(f_size,f_table)
  124.     integer :: f_size, f_1, f_2
  125.     character :: f_table(f_size,f_size)
  126.     !
  127.     full = .true.
  128.     do f_1 =1,f_size
  129.         do f_2 =1, f_size
  130.             if ( f_table(f_1,f_2) == '-' ) then
  131.                 full = .false.
  132.                 return
  133.             end if
  134.         end do
  135.     end do
  136. end function
  137. !
  138. !способ проверки выигрыша - так как поле и размер клеток, нужных для выигрыша не совпадает
  139. !мы создаём процедуру, режущую исходное поле на поля размером количество клеток для выигрыша
  140. !на количество клеток для выигрыша
  141. subroutine equate(eq_size, eq_win, eq_table, eq_win_table, eq_pw_1, eq_pw_2)
  142.     integer :: eq_size, eq_win, eq_pw_1, eq_pw_2, eq_1, eq_2
  143.     character :: eq_table(eq_size, eq_size), eq_win_table(eq_win, eq_win)
  144.     !
  145.     do eq_1 =1, eq_win
  146.         do eq_2 =1, eq_win
  147.             eq_win_table(eq_1,eq_2) = eq_table( (eq_pw_1+eq_1-1),(eq_pw_2+eq_2-1) )
  148.         end do
  149.     end do
  150. end subroutine
  151. !
  152. !функция выигрыша в обрезанной таблице
  153. integer function cut_win(cw_win, cw_table)
  154.     integer :: cw_win, cw_1,cw_2
  155.     character :: cw_table(cw_win,cw_win), cw_array(cw_win),cw_x(cw_win),cw_0(cw_win)
  156.     logical :: is_equal
  157.     !
  158.     cw_x(:) = 'x'
  159.     cw_0(:) = '0'
  160.     cut_win = 0
  161.     !первая диагональ
  162.     do cw_1 =1,cw_win
  163.         cw_array(cw_1) = cw_table(cw_1,cw_1)
  164.     end do
  165.     if (is_equal(cw_x,cw_array,cw_win)) then
  166.         cut_win = 1
  167.         return
  168.     elseif (is_equal(cw_0,cw_array,cw_win)) then
  169.         cut_win = 2
  170.         return
  171.     end if
  172.     !вторая диагональ
  173.     do cw_1 =1,cw_win
  174.         cw_array(cw_1) = cw_table(cw_1,(cw_win-cw_1+1))
  175.     end do
  176.     if (is_equal(cw_x,cw_array,cw_win)) then
  177.         cut_win = 1
  178.         return
  179.     elseif (is_equal(cw_0,cw_array,cw_win)) then
  180.         cut_win = 2
  181.         return
  182.     end if
  183.     !горизонтали
  184.     do cw_1 =1,cw_win
  185.         do cw_2 =1,cw_win
  186.             cw_array(cw_2) = cw_table(cw_1,cw_2)
  187.         end do
  188.         if (is_equal(cw_x,cw_array,cw_win)) then
  189.             cut_win = 1
  190.             return
  191.         elseif (is_equal(cw_0,cw_array,cw_win)) then
  192.             cut_win = 2
  193.             return
  194.         end if
  195.     end do
  196.     !вертикали
  197.     do cw_1 =1,cw_win
  198.         do cw_2 =1,cw_win
  199.             cw_array(cw_2) = cw_table(cw_2,cw_1)
  200.         end do
  201.         if (is_equal(cw_x,cw_array,cw_win)) then
  202.             cut_win = 1
  203.             return
  204.         elseif (is_equal(cw_0,cw_array,cw_win)) then
  205.             cut_win = 2
  206.             return
  207.         end if
  208.     end do
  209. end function
  210. !
  211. !эквивалентность двух массивов
  212. logical function is_equal(ie_a, ie_b, ie_n)
  213. integer :: ie_n, ie_i
  214. character :: ie_a(ie_n),ie_b(ie_n)
  215. do ie_i = 1, ie_n
  216.     if(ie_a(ie_i) /= ie_b(ie_i)) then
  217.         is_equal= .false.
  218.         return
  219.     end if
  220. end do
  221. is_equal =.true.
  222. end function
  223.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement