码迷,mamicode.com
首页 > 其他好文 > 详细

BZOJ 3668:起床困难综合症(贪心)

时间:2017-04-12 20:39:52      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:begin   else   reset   技术   span   eset   ram   array   closed   

分析:按位贪心即可。

技术分享
program sleep;
var
  a,g:array[0..150000]of longint;
  n,i,m,ans,t,len,x,y,v:longint;
  c:char; s:string; e:boolean;
function cheak(x,y:longint):longint;
var i:longint;
begin
  for i:=1 to n do
   begin
     if g[i]=1 then x:=x and (a[i] shr (y-1) and 1);
     if g[i]=2 then x:=x or (a[i]  shr (y-1) and 1);
     if g[i]=3 then x:=x xor (a[i] shr (y-1) and 1);
   end;
  exit(x);
end;
begin
   assign(input,sleep.in);
reset(input);
assign(output,sleep.out);
rewrite(output);
  readln(n,m);
  for i:=1 to n do
   begin
     readln(s); t:=pos( ,s); c:=s[1];
     if c=A then g[i]:=1;
     if c=O then g[i]:=2;
     if c=X then g[i]:=3;
     val(copy(s,t+1,length(s)-t),a[i]);
   end;
   ans:=0; e:=false;
   for i:=30 downto 1 do
    begin
      if cheak(0,i)=1 then begin x:=0; y:=1; end
       else if cheak(1,i)=1 then
        begin
          if (e=false)and(m shr (i-1)=0) then begin x:=0; y:=0; end
                else begin x:=1; y:=1; end;
        end
      else begin x:=0; y:=0; end;
      v:=v+x*(1 shl (i-1));
      ans:=ans+y*(1 shl (i-1));
      if v<m shr (i-1) then e:=true;
    end;
   writeln(ans);
   close(input); close(output);
end.
View Code

 

BZOJ 3668:起床困难综合症(贪心)

标签:begin   else   reset   技术   span   eset   ram   array   closed   

原文地址:http://www.cnblogs.com/qtyytq/p/6701078.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!