替换表中的字符 - ADA

时间:2012-12-02 11:19:50

标签: ada tabular

我在表格中创建了一个包含字符的表格(62 x 35)。我正试图用中间的方式替换10 x 10表中的字符。

例如,如果我有一个看起来像这样的表:(62 x 35)

##############################################################
##############################################################
##############################################################
##############################################################
##############################################################
##############################################################
##############################################################
##############################################################
##############################################################
##############################################################
############################################################## 
##############################################################
##############################################################
##############################################################
##############################################################
##############################################################
##############################################################
##############################################################

我希望能够加载包含(10x10)的文件:

//////////
//////////
//////////
//////////
//////////
//////////
//////////
//////////
//////////
//////////

以便此文件中的字符替换先前创建的表中的字符

即。有一个看起来像

的表
##############################################################
##############################################################
##############################################################
##############################################################
##############################################################
##############################################################
##########################//////////##########################
##########################//////////##########################
##########################//////////##########################
##########################//////////##########################
##########################//////////##########################
##########################//////////##########################
##########################//////////##########################
##########################//////////##########################
##########################//////////##########################
##########################//////////##########################
##############################################################
##############################################################
##############################################################
##############################################################
##############################################################

我不认为我想要做的事情非常清楚,所以如果你想了解更多细节,请询问。

procedure Grid_Pilliers(A: out Grid) is  -- creates grid with pilliers --
begin
   for I in 0..31 loop
      for J in 0..75 loop
         if (I mod 4 = 1 or I mod 4 = 0) and (J mod 4 = 1 or J mod 4 = 0) then
            A(I,J) := true ;
         else
            A(I,J) := false ;
         end if ;
      end loop ;
   end loop ;
end Grid_Pilliers ;


procedure New_Grid_Random_Fill(A : in out New_Grid) is

   type Numero is range 0 .. 1;
   package Grid_Random is new Ada.Numerics.Discrete_Random (Numero);
   use Grid_Random;
   Random_Number : Numero;
   G : Generator;

begin
   Reset (G);
   for I in A'Range(1) loop
      for J in A'Range(2) loop
         Random_Number := Random (G);
         A(I,J) := (Random_Number = 1);
      end loop;
   end loop;
end New_Grid_Random_Fill;

1 个答案:

答案 0 :(得分:1)

你应该使用切片......但是对于这个例子,我将使用一对for循环。 假设您将表类型(Grid)定义为Array (Positive Range <>, Positive Range <>) of Character ...

procedure copy_into( Working : in out Grid; subimage : in Grid;
                     Offset_X, Offset_Y : Natural ) is
begin
 -- insert checks for subimage lengths [plus offsets]
 -- to be less than Working's lengths.

 for index_x in subimage'Range(1) loop
   for index_y in subimage'Range(2) loop
     Working(index_x+offset_x, index_y+offset_y):= subimage(index_x, index_y);
   end loop;
 end loop;
end copy_into;

要获得偏移很简单:

offset_x = big_grid_width + small_grid_width / 2.

offset_y =以上,但使用高度。