Spinning Wheels (spin)[USACO 3.2.3]

算法:模拟
 
分析:总之就是先画个扇形,标记为true的时间点一定位于这个扇形里面,表示这个是起点。
      然后我们根据起点进行旋转,这里可以证明我们最多就旋转359次,再多了就是没用的了,然后按照速度进行再次确认,只有通过起点旋转过来的才标记为true。
      最后判断输出一下即可。     
{

ID:1011mashuo

TASK:spin

LANG:PASCAL

}



var

 i,j,k,t,s:longint;

 v:array[1..5] of longint;

 m,w:array[1..5,0..359] of boolean;



begin

 assign(input,'spin.in'); reset(input);

 assign(output,'spin.out'); rewrite(output);



 for i:=1 to 5 do

  begin

   read(v[i]);

   read(t);

   for j:=1 to t do

    begin

     read(s,t);

     for k:=s to s+t do w[i,k mod 360]:=true;

    end;

   readln;

  end;

 for i:=0 to 359 do

  begin

   for j:=1 to 5 do for k:=0 to 359 do m[j,(k+v[j]*i) mod 360]:=w[j,k];

   for k:=0 to 359 do

    begin

     for j:=1 to 5 do if not m[j,k] then break;

     if m[j,k] then break;

    end;

   if m[j,k] then break;

  end;

 if m[j,k] then writeln(i) else writeln('none');



 close(input); close(output);

end.


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值