jzoj 1147. WING(wing)

本文介绍了一个名为WING的拼图游戏算法挑战题,通过使用Pascal语言实现了一个程序来解决该问题。该程序读取输入文件wing.in,并将结果输出到wing.out。文章提供了一个示例代码,展示了如何通过数组记录状态并更新输出。
题目描述
输入
输出
样例输入
对于这道题,如果把它理解为一个拼图游戏,其实很简单,代码如下:
var
 f:array[1..10,'A'..'Z']of longint;
 n,c,ans,i,j,k,l:longint;   s:string;

begin
 assign(input,'wing.in'); reset(input);
 assign(output,'wing.out'); rewrite(output);
 readln(n,c);
 for i:=1 to c do
  begin
   read(j,s);
   delete(s,1,1);
   l:=0;
   if j=1 then
    begin
     for k:=1 to n do
     begin
      if f[k,s[k]]=0 then begin l:=-1; break; end;
      if f[k,s[k]]>l then l:=f[k,s[k]];
     end;
    end
   else
    begin
     inc(ans);
     for k:=1 to n do
      if f[k,s[k]]=0 then f[k,s[k]]:=ans;
    end;
  if j=1 then  writeln(l);
 end;
 close(input); close(output);
end.

样例输出
-1
1
2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值