noi.ac #42 :queen 連if都不用肖方! (NOIP模擬賽 第六場2018-09-23 08:30:30)

OJ入口:noi.ac

題目鏈接:http://noi.ac/contest/15/problem/42

比賽成績就不說了...本題解是在比賽完后的那個(gè)晚上洗澡時(shí)想出來的...

話說想出來了是真簡單...80ms不到就A了...

先說說大概思路:

創(chuàng)建對(duì)于一個(gè)位點(diǎn)的八個(gè)方向的一維數(shù)組(就是這個(gè)點(diǎn)的左邊絮缅,右邊膀曾,上邊酒唉,下邊叁熔,左上委乌,左下,右上者疤,右下),用來儲(chǔ)存該位點(diǎn)是否會(huì)受到攻擊福澡。最后累加每個(gè)方向的結(jié)果:

Qr[left_+right+up+down+left_up+left_down+right_up+right_down]++;//Qr用來表示儲(chǔ)存會(huì)受到各攻擊次數(shù)皇后的個(gè)數(shù)

最后輸出 Qr[0-8]即可

題目相信都看得懂,這里就不多說了驹马,直接說題解

注意革砸! 1<=x,y<=10e5??

先來define點(diǎn)東西...

const int MAXN=100005,MAX_T=0x7f7f7f7f;

int n,m,x,y,X,w,i,res,xy,xyn;// >>>> 注意糯累! 1<=x,y<=10e5 <<<<

//n棋盤邊長,m棋子個(gè)數(shù)算利,x,y坐標(biāo) 泳姐,X效拭,w讀入優(yōu)化需要 ,i循環(huán)需要,res受攻擊數(shù)缎患,xy=x+y慕的,xyn=x-y+n 用于表示 (x,y)所在的斜...

char ch;//用于讀入優(yōu)化

int Qr[9];//被攻擊次數(shù)保存數(shù)據(jù) int vt[MAXN][2];

int min_x[MAXN],max_x[MAXN],min_y[MAXN],max_y[MAXN],min_xy[2*MAXN],max_xy[2*MAXN],min_xyn[2*MAXN],max_xyn[2*MAXN];

我們?cè)賮懋嬕粡埐]有什么用的棋盤...

拿第一個(gè)樣例來說,下面是一張8*8的棋盤?

8*8棋盤

數(shù)據(jù):4? 3 挤渔,4? 8肮街, 6? 5 ,1? 6

然后判导,讀入數(shù)據(jù)

inline int iread(){//讀入優(yōu)化不多說

? ? ?X=0,w=0; ch=0;

? ? ?while(!isdigit(ch)) {w|=ch=='-';ch=getchar();}

? ? ?while(isdigit(ch)) X=(X<<3)+(X<<1)+(ch^48),ch=getchar();

? ? ?return w?-X:X;

}

void initData(){ memset(min_x,0x7f,sizeof(min_x)); memset(min_y,0x7f,sizeof(min_y)); memset(min_xy,0x7f,sizeof(min_xy)); memset(min_xyn,0x7f,sizeof(min_xyn)); n=iread(); m=iread(); for(i=0;i<m;i++){ x=iread();y=iread(); vt[i][0]=x;//儲(chǔ)存坐標(biāo)數(shù)據(jù) vt[i][1]=y; xy=x+y; xyn=x-y+n; min_x[y]=min(min_x[y],x); max_x[y]=max(max_x[y],x); min_y[x]=min(min_y[x],y); max_y[x]=max(max_y[x],y); min_xy[xy]=min(min_xy[xy],x);//左下右上 max_xy[xy]=max(max_xy[xy],x); min_xyn[xyn]=min(min_xyn[xyn],x);//左上右下 max_xyn[xyn]=max(max_xyn[xyn],x); }}

難受...不會(huì)排版直接上圖...

initData();

首先把min啥的全部開最大...不多說memset( xxx,0x7f,sizeof(xxx))...注意數(shù)組開出來后數(shù)據(jù)是MAX_T=0x7f7f7f7f...

然后iread()優(yōu)化讀入數(shù)據(jù)...

重點(diǎn)來了↓↓↓

xy=x+y;//不難發(fā)現(xiàn)嫉父,x+y可以表示同一斜(左上到右下↖ ↘ )

xyn=x-y+n;//起始x-y可以表示同一斜(左下到右上↙ ↗),+n是因?yàn)閤yn需要做下標(biāo)故需要為正

min_x[y]=min(min_x[y],x);//獲取y行最左邊的皇后x坐標(biāo)

max_x[y]=max(max_x[y],x);//獲取y行最右邊的皇后x坐標(biāo)

min_y[x]=min(min_y[x],y);//獲取x列最下邊的皇后y坐標(biāo)

max_y[x]=max(max_y[x],y);//獲取x列最上邊的皇后y坐標(biāo)

min_xy[xy]=min(min_xy[xy],x);//獲取同一溜最左上的皇后x坐標(biāo) (其實(shí)y也行

max_xy[xy]=max(max_xy[xy],x);//獲取同一溜最右下的皇后x坐標(biāo)

min_xyn[xyn]=min(min_xyn[xyn],x);//獲取同一溜最左下的皇后x坐標(biāo)

max_xyn[xyn]=max(max_xyn[xyn],x);//獲取同一溜最右上的皇后x坐標(biāo)

填圖后...星星就看做皇后吧:)MAX_T表示最大值0x7f7f7f7f

偽填圖..

斜著的就不寫了眼刃,道理是一樣的...

initData()完了后呢绕辖,我們來check()一遍

void check(){ for(i=0;i<m;i++){ res=0; x=vt[i][0];//挨個(gè)獲取皇后坐標(biāo)x,y y=vt[i][1]; xy=x+y; xyn=x-y+n; //check left res += x>min_x[y]&&min_x[y]!=MAX_T; //check right res += x<max_x[y]&&max_x[y]!=0; //check down res += y>min_y[x]&&min_y[x]!=MAX_T; //check up res += y<max_y[x]&&max_y[x]!=0; //check xy left res += x>min_xy[xy]&&min_xy[xy]!=MAX_T; //check xy right res += x<max_xy[xy]&&max_xy[xy]!=0; //check xyn left res += x>min_xyn[xyn]&&min_xyn[xyn]!=MAX_T; //check xyn right res += x<max_xyn[xyn]&&max_xyn[xyn]!=0; Qr[res]++; }}

......T^T(內(nèi)心十分難受擂红,誰能教我排版...)直接上圖吧...


話說這操作仪际!顯而易見這是在統(tǒng)計(jì)被攻擊的次數(shù)嘛...(register宏定義...其實(shí)對(duì)時(shí)間影響不大...詳細(xì)見下面我兩次ac記錄時(shí)間對(duì)比)

總的來說,大于最小的篮条,小于最大的弟头,然后你就被攻擊了...

拿一行來舉例:

res += x>min_x[y];

如果這個(gè)皇后在這一行最左邊的皇后的右邊...那么這個(gè)皇后就會(huì)被攻擊!

然后...就寫完了....

在輸出一下Qr[0-8]...

void PutOut(){

? ? ?for(register int i=0;i<9;i++)

? ? ? ? ? printf("%d ",Qr[i]);

}??

不對(duì)...main還沒寫...補(bǔ)上...

```

int main(){

? ? ?initData();//讀入...

? ? ?check();//檢查所有皇后...

? ? ?PutOut();//輸出答案...

? ? ?return 0;

}?

```

就這樣...寫完了...來提交一波


noi.ac #42 queen AC記錄

嗯...后邊兩次去掉了部分無用代碼...加入了作用不大的register...


noi.ac #42 queen AC統(tǒng)計(jì)

wtf!居然還上榜了涉茧!嘿嘿嘿...(雷布斯說赴恨,厚道的人運(yùn)氣不會(huì)太差哦)

RTRTRT!代碼附上 ,證明一下...(雖然亂成一坨)...是在看著不想復(fù)制的話就點(diǎn)下邊這個(gè)吧...

點(diǎn)擊查看codehttp://noi.ac/submission/12865

```

#include<bits/stdc++.h>using namespace std;const int MAXN=100005;const int MAX_T=0x7f7f7f7f;int n,m,x,y,X,w,i,res,xy,xyn;// >>>> 注意伴栓! 1<=x,y<=10e5 <<<<char ch;int Qr[9];//被攻擊次數(shù)保存數(shù)據(jù) int vt[MAXN][2];int min_x[MAXN],max_x[MAXN],min_y[MAXN],max_y[MAXN],min_xy[2*MAXN],max_xy[2*MAXN],min_xyn[2*MAXN],max_xyn[2*MAXN];inline int iread(){ X=0,w=0; ch=0; while(!isdigit(ch)) {w|=ch=='-';ch=getchar();} while(isdigit(ch)) X=(X<<3)+(X<<1)+(ch^48),ch=getchar(); return w?-X:X;}void initData(){ memset(min_x,0x7f,sizeof(min_x)); memset(min_y,0x7f,sizeof(min_y)); memset(min_xy,0x7f,sizeof(min_xy)); memset(min_xyn,0x7f,sizeof(min_xyn)); n=iread(); m=iread(); for(i=0;i<m;i++){ x=iread();y=iread(); vt[i][0]=x;//儲(chǔ)存坐標(biāo)數(shù)據(jù) vt[i][1]=y; xy=x+y; xyn=x-y+n; min_x[y]=min(min_x[y],x); max_x[y]=max(max_x[y],x); min_y[x]=min(min_y[x],y); max_y[x]=max(max_y[x],y); min_xy[xy]=min(min_xy[xy],x);//左下右上 max_xy[xy]=max(max_xy[xy],x); min_xyn[xyn]=min(min_xyn[xyn],x);//左上右下 max_xyn[xyn]=max(max_xyn[xyn],x); }}void check(){ for(i=0;i<m;i++){ res=0; x=vt[i][0];//挨個(gè)獲取皇后坐標(biāo)x伦连,y y=vt[i][1]; xy=x+y; xyn=x-y+n; //check left res += x>min_x[y]&&min_x[y]!=MAX_T; //check right res += x<max_x[y]&&max_x[y]!=0; //check down res += y>min_y[x]&&min_y[x]!=MAX_T; //check up res += y<max_y[x]&&max_y[x]!=0; //check xy left res += x>min_xy[xy]&&min_xy[xy]!=MAX_T; //check xy right res += x<max_xy[xy]&&max_xy[xy]!=0; //check xyn left res += x>min_xyn[xyn]&&min_xyn[xyn]!=MAX_T; //check xyn right res += x<max_xyn[xyn]&&max_xyn[xyn]!=0; Qr[res]++; }}void PutOut(){ for(i=0;i<9;i++) printf("%d ",Qr[i]);}int main(){ initData(); check(); PutOut(); return 0;}

```

***

(第二次寫簡書...經(jīng)驗(yàn)還是不夠,希望各位dalao們多多指教钳垮!以后會(huì)更新關(guān)于android開發(fā)和java的一些demo與算法惑淳,oj ac記錄主要以c++為主)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市饺窿,隨后出現(xiàn)的幾起案子歧焦,更是在濱河造成了極大的恐慌,老刑警劉巖肚医,帶你破解...
    沈念sama閱讀 217,826評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件绢馍,死亡現(xiàn)場離奇詭異,居然都是意外死亡肠套,警方通過查閱死者的電腦和手機(jī)舰涌,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來你稚,“玉大人瓷耙,你說我怎么就攤上這事朱躺。” “怎么了搁痛?”我有些...
    開封第一講書人閱讀 164,234評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵长搀,是天一觀的道長。 經(jīng)常有香客問我鸡典,道長盈滴,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,562評(píng)論 1 293
  • 正文 為了忘掉前任轿钠,我火速辦了婚禮,結(jié)果婚禮上病苗,老公的妹妹穿的比我還像新娘疗垛。我一直安慰自己,他們只是感情好硫朦,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評(píng)論 6 392
  • 文/花漫 我一把揭開白布贷腕。 她就那樣靜靜地躺著,像睡著了一般咬展。 火紅的嫁衣襯著肌膚如雪泽裳。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,482評(píng)論 1 302
  • 那天破婆,我揣著相機(jī)與錄音涮总,去河邊找鬼。 笑死祷舀,一個(gè)胖子當(dāng)著我的面吹牛瀑梗,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播裳扯,決...
    沈念sama閱讀 40,271評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼抛丽,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了饰豺?” 一聲冷哼從身側(cè)響起亿鲜,我...
    開封第一講書人閱讀 39,166評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎冤吨,沒想到半個(gè)月后蒿柳,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,608評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡锅很,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評(píng)論 3 336
  • 正文 我和宋清朗相戀三年其馏,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片爆安。...
    茶點(diǎn)故事閱讀 39,926評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡叛复,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情褐奥,我是刑警寧澤咖耘,帶...
    沈念sama閱讀 35,644評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站撬码,受9級(jí)特大地震影響儿倒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜呜笑,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評(píng)論 3 329
  • 文/蒙蒙 一夫否、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧叫胁,春花似錦凰慈、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至输钩,卻和暖如春豺型,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背买乃。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評(píng)論 1 269
  • 我被黑心中介騙來泰國打工姻氨, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人剪验。 一個(gè)月前我還...
    沈念sama閱讀 48,063評(píng)論 3 370
  • 正文 我出身青樓哼绑,卻偏偏與公主長得像,于是被迫代替她去往敵國和親碉咆。 傳聞我的和親對(duì)象是個(gè)殘疾皇子抖韩,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評(píng)論 2 354