[Back to MISC SWAG index]  [Back to Main SWAG index]  [Original]

{
pigeons@JSP.UMontreal.CA (Pigeon Steven)

>     Hey, I have a friend who is taking a Pascal class at another col-
>lege and he asked me to make a query of you all.  Basically, he has to
>do the "eight queens" on a chessboard (with none of them interfering
>vertically, horizontally, or diagonally with each other) problem in
>Pascal.  The program has to use stacks.  Its input is the number of
>queens (the dimensions of the chessboard are that number x that number).
>The output is that it can't be done with that number of queens or a
>grid of the queens and either empty spaces or dashes.  I was wondering
>if any of you had any similar programs in old code lying around, and if
>so if you could send it to me.  My friend says it's a pretty classic
>problem for programmers, so I figured I'd ask.  Oh, and in case some of
>you think that I am this "friend", the only Pascal course here at Brown
>(cs15) has already done its job with stacks, and it wasn't this.  Btw,
>speaking of cs here, it's Object-Oriented; my friend's program needs to
>be done procedureally (straight-line), not in OOPas.  I thank you all
>for your indulgence in allowing me to post this.  Please don't flame me,
>as I am only trying to help out a friend.  If there is a more appropriate
>place for me to post this, please tell me (I am going to post this to
>cs groups if possible).  Oh, and as I don't get around here often, I
>would appreciate it much if any and all replies were sent to the address
>below.  Thanx,
>

Here's a programm that does that. It's a little bit strange, but I put
extra code so the board would not be passed as a parameter (since Turbo
Profiler said :"Hey, 75% of your run time goes in copy of the board").
The file is name REINES5.PAS (litterally QUEENS5.PAS) and it's limited
(so to say) to 64x64 boards (with 64 queens on it). It is fast enough.


}
 program Probleme_des_reines;

 const max = 64;
       libre = 8;
       reine = 8;

 const colname:string =
                        'abcdefghijklmnopqrstuvwxyz'+
                        'ABCDEFGHIJKLMNOPQRSTUVWXYZ'+
                        'àáâçäåæèéêë';
 type echiquier = array[1..max,1..max] of byte;
 var  sol,recursions:longint;
      top:word;
      Reines,Attaques:echiquier;


 function min(a,b:integer):integer;
  begin
   if a<b
      then min:=a
      else min:=b;
  end;

 procedure mark(x,y:integer);
 var t,g,i:integer;
  begin
   for t:=y+1 to top do inc(attaques[x,t]);

   t:=x+1;
   g:=y+1;

   for i:=1 to min(top-t,top-g)+1 do
    begin
     inc(attaques[t,g]);
     inc(t);
     inc(g);
    end;

   t:=x-1;
   g:=y+1;

   if t>0 then
   for i:=1 to min(top-g+1,t) do
    begin
     inc(attaques[t,g]);
     dec(t);
     inc(g);
    end;

   Reines[x,y]:=reine;

  end;

 procedure unmark(x,y:integer);
 var t,g,i:integer;
  begin
   for t:=y+1 to top do dec(attaques[x,t]);

   t:=x+1;
   g:=y+1;

   for i:=1 to min(top-t,top-g)+1 do
    begin
     dec(attaques[t,g]);
     inc(t);
     inc(g);
    end;


   t:=x-1;
   g:=y+1;

   if t>0 then
   for i:=1 to min(top-g+1,t) do
    begin
     dec(attaques[t,g]);
     dec(t);
     inc(g);
    end;

   Reines[x,y]:=libre;

  end;



 procedure traduit;
 var t,g:integer;
  begin
   write(sol:4,'. ');
   for t:=1 to top do
    for g:=1 to top do
     if Reines[g,t]=reine then write(colname[t],g,' ');
   writeln('  ',recursions);
  end;


 function find(level,j:integer):integer;
  begin
   inc(j);
   while (attaques[j,level]<>libre) and (j<top) do inc(j);
   if (attaques[j,level]=libre)
      then find:=j
      else find:=0;
  end;



 procedure recurse(level:integer);
 var t:integer;
  begin
   inc(recursions);
   t:=0;
   repeat
    t:=find(level,t);
    if t<>0
       then begin
             if level=top
                then begin
                      inc(sol);
                      Reines[t,level]:=reine;
                      traduit;
                      Reines[t,level]:=libre;
                     end
                else begin
                      mark(t,level);
                      recurse(level+1);
                      unmark(t,level);
                     end;
            end
   until (t=0) or (t=top);
  end;


  function fact(n:real):real;
   begin
    if n<=1 then fact:=1
            else fact:=n*fact(n-1);
   end;


 var a:echiquier;
     i:integer;
 begin


  sol:=0;
  val(paramstr(1),top,i);
  if top>max
     then begin
           writeln('! ',Top,' a ete remis a ',max,' (max)');
           top:=max;
          end;

  if top<1 then top:=1;

  writeln;
  writeln(' Le probleme des ',top,' reines FAST (c) 1992-1993 Steven Pigeon');
  writeln;

  recursions:=0;
  fillchar(attaques,sizeof(attaques),libre);
  fillchar(Reines,sizeof(Reines),libre);
  recurse(1);
  writeln;
  writeln(' Solutions: ',sol);
  writeln(' Recursions: ',recursions,' (au lieu de ',fact(top):0:0,')');
 end.


[Back to MISC SWAG index]  [Back to Main SWAG index]  [Original]