usaco1.2 palsquare 2008.11.5

usaco1.2 palsquare 2008.11.5

{Tips:

1.注意正序和逆序的问题,b进制下的平方因为是回文数,不必考虑这个问题。但原数输出时需要考虑转为b进制时的数字顺序,一定要看清楚输出的顺序

2.题目中说,1-300的原数也要b进制输出,这点我忽略了。一定要看清楚题目让如何输出}


{
ID: 
PROG: palsquare
LANG: PASCAL
}
  program kakashi;
  type
    arr=array[1..20]of char;
   var
    x:array[0..20]of char=('0','1','2','3','4','5','6',
                           '7','8','9','A','B','C','D',
                           'E','F','G','H','I','J','K');
    k,tt,i,j,n,yn,code,u,ii:longint;
    f1,f2:text;
    flag:boolean;
    a,b:arr;
    function deal:boolean;
      var
        p:longint;
        begin
          deal:=true;
          for p:=1 to (j div 2) do
            if (a[p]<>a[j+1-p]) then deal:=false;
        end;
    begin
     assign(f1,'palsquare.in');
     reset(f1);
     assign(f2,'palsquare.out');
     rewrite(f2);
     readln(f1,n);
     for i:=1 to 300 do
       begin
         u:=0;
         ii:=i;
         repeat
           inc(u);
           b[u]:=x[ii mod n];
           ii:=ii div n;
         until ii<n;
         if ii<>0 then begin inc(u);b[u]:=x[ii];end;
         tt:=i*i;
         j:=0;
         repeat
           inc(j);
           a[j]:=x[tt mod n];
           tt:=tt div n;
         until tt<n;
         if tt<>0 then begin inc(j); a[j]:=x[tt];end;
         flag:=deal;
         if flag then
           begin
             for k:=u downto 1 do
               write(f2,b[k]);
               write(f2,' ');
             for k:=1 to j do
               write(f2,a[k]);
               writeln(f2);
           end;
       end;
       close(f1);
       close(f2);
      end.


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值