description
21 世紀,許多人得了一種奇怪的病:起床困難綜合症,其臨床表現為:起床難,起床後精神不佳。作為一名青春陽光好少年,atm 一直堅持與起床困難綜合症作鬥爭。通過研究相關文獻,他找到了該病的發病原因:在深邃的太平洋海底中,出現了一條名為 drd 的巨龍,它掌握著睡眠之精髓,能隨意延長大家的睡眠時間。正是由於 drd 的活動,起床困難綜合症愈演愈烈,以驚人的速度在世界上傳播。為了徹底消滅這種病,atm 決定前往海底,消滅這條惡龍。歷經千辛萬苦,atm 終於來到了 drd 所在的地方,準備與其展開艱苦卓絕的戰鬥。drd 有著十分特殊的技能,他的防禦戰線能夠使用一定的運算來改變他受到的傷害。具體說來,drd 的防禦戰線由 n扇防禦門組成。每扇防禦門包括乙個運算op和乙個引數t,其中運算一定是or,xor,and中的一種,引數則一定為非負整數。如果還未通過防禦門時攻擊力為x,則其通過這扇防禦門後攻擊力將變為x op t。最終drd 受到的傷害為對方初始攻擊力x依次經過所有n扇防禦門後轉變得到的攻擊力。由於atm水平有限,他的初始攻擊力只能為0到m之間的乙個整數(即他的初始攻擊力只能在0,1,…,m中任選,但在通過防禦門之後的攻擊力不受 m的限制)。為了節省體力,他希望通過選擇合適的初始攻擊力使得他的攻擊能讓 drd 受到最大的傷害,請你幫他計算一下,他的一次攻擊最多能使 drd 受到多少傷害。
input
第1行包含2個整數,依次為n,m,表示drd有n扇防禦門,atm的初始攻擊力為0到m之間的整數。接下來n行,依次表示每一扇防禦門。每行包括乙個字串op和乙個非負整數t,兩者由乙個空格隔開,且op在前,t在後,op表示該防禦門所對應的操作, t表示對應的引數。n<=10^5
output
一行乙個整數,表示atm的一次攻擊最多使 drd 受到多少傷害。
貪心,從高位到低位,能讓這位結果是1就讓它是1,在可以是1的基礎上能讓這位最初是0就讓它是0。為什麼wa了呢?因為要先判斷這位是0的時候可不可以使結果為1,那之後才判斷這位是1超不超m。。。
自己的**:
#include
#include
using
namespace
std;
typedef
unsigned
int uint;
uint n,m,now=0,ans=0;
uint val[100001];
uint maxx;
char ope[100001][3];
bool check(bool k,int w)
}return k;
}int main()
for(int i=log2(maxx);i>=0;i--)
998 起床困難綜合症
本題是讓我們選擇 0,m 之間的乙個整數x,經過給定的n次位運算,使結果ans最大。位運算的主要特點之一是在二進位制表示下不進製。正因為如此,在x可以任意選擇的情況下從,參與位運算的各個位 bit 之間是獨立無關的。換言之,對於任意的k 0 k 30 ans的第k位是幾 只與 x的第k位是幾 有關,...
codevs3311 起床困難綜合症
題目 wwq 這題你居然沒一眼切?嗯 二進位制列舉 判斷不超過m的二進位制數的每一位是1更優還是0更優 顯然同時滿足我們要放0 為了便於判斷大小,從高位到低位列舉 複雜度 2 n log m include include include include define ll long long us...
NOI2014 起床困難綜合症
noi2014 起床困難綜合症 又刷了一道水題qwq 它給你n扇門,每扇門都有乙個值和乙個操作,這個操作為or and xor之間的某乙個。你需要從m中任意選取乙個數,使得這個數依次經過n扇門之後的值最大。n是1e5的,m是1e9的,如果你直接暴力列舉每乙個數,求最大值,複雜度顯然是1e14的,了。...