noi.ac #42 :queen 连if都不用! (NOIP模拟赛 第六场2018-09-23 08:30:30)

OJ入口:noi.ac

题目链接:http://noi.ac/contest/15/problem/42

比赛成绩就不说了...本题解是在比赛完后的那个晚上洗澡时想出来的...

话说想出来了是真简单...80ms不到就A了...

先说说大概思路:

创建对于一个位点的八个方向的一维数组(就是这个点的左边,右边,上边,下边,左上,左下,右上,右下),用来储存该位点是否会受到攻击。最后累加每个方向的结果:

Qr[left_+right+up+down+left_up+left_down+right_up+right_down]++;//Qr用来表示储存会受到各攻击次数皇后的个数

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

题目相信都看得懂,这里就不多说了,直接说题解

注意! 1<=x,y<=10e5  

先来define点东西...

const int MAXN=100005,MAX_T=0x7f7f7f7f;

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

//n棋盘边长,m棋子个数,x,y坐标 ,X,w读入优化需要 ,i循环需要,res受攻击数,xy=x+y,xyn=x-y+n 用于表示 (x,y)所在的斜...

char ch;//用于读入优化

int Qr[9];//被攻击次数保存数据 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];

我们再来画一张并没有什么用的棋盘...

拿第一个样例来说,下面是一张8*8的棋盘 

8*8棋盘

数据:4  3 ,4  8, 6  5 ,1  6

然后,读入数据

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;//储存坐标数据 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); }}

难受...不会排版直接上图...

initData();

首先把min啥的全部开最大...不多说memset( xxx,0x7f,sizeof(xxx))...注意数组开出来后数据是MAX_T=0x7f7f7f7f...

然后iread()优化读入数据...

重点来了↓↓↓

xy=x+y;//不难发现,x+y可以表示同一斜(左上到右下↖ ↘ )

xyn=x-y+n;//起始x-y可以表示同一斜(左下到右上↙ ↗),+n是因为xyn需要做下标故需要为正

min_x[y]=min(min_x[y],x);//获取y行最左边的皇后x坐标

max_x[y]=max(max_x[y],x);//获取y行最右边的皇后x坐标

min_y[x]=min(min_y[x],y);//获取x列最下边的皇后y坐标

max_y[x]=max(max_y[x],y);//获取x列最上边的皇后y坐标

min_xy[xy]=min(min_xy[xy],x);//获取同一溜最左上的皇后x坐标 (其实y也行

max_xy[xy]=max(max_xy[xy],x);//获取同一溜最右下的皇后x坐标

min_xyn[xyn]=min(min_xyn[xyn],x);//获取同一溜最左下的皇后x坐标

max_xyn[xyn]=max(max_xyn[xyn],x);//获取同一溜最右上的皇后x坐标

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

伪填图..

斜着的就不写了,道理是一样的...

initData()完了后呢,我们来check()一遍

void check(){ for(i=0;i<m;i++){ res=0; x=vt[i][0];//挨个获取皇后坐标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(内心十分难受,谁能教我排版...)直接上图吧...


话说这操作!显而易见这是在统计被攻击的次数嘛...(register宏定义...其实对时间影响不大...详细见下面我两次ac记录时间对比)

总的来说,大于最小的,小于最大的,然后你就被攻击了...

拿一行来举例:

res += x>min_x[y];

如果这个皇后在这一行最左边的皇后的右边...那么这个皇后就会被攻击!

然后...就写完了....

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

void PutOut(){

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

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

}  

不对...main还没写...补上...

```

int main(){

     initData();//读入...

     check();//检查所有皇后...

     PutOut();//输出答案...

     return 0;

```

就这样...写完了...来提交一波


noi.ac #42 queen AC记录

嗯...后边两次去掉了部分无用代码...加入了作用不大的register...


noi.ac #42 queen AC统计

wtf!居然还上榜了!嘿嘿嘿...(雷布斯说,厚道的人运气不会太差哦)

RTRTRT!代码附上 ,证明一下...(虽然乱成一坨)...是在看着不想复制的话就点下边这个吧...

点击查看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];//被攻击次数保存数据 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;//储存坐标数据 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];//挨个获取皇后坐标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;}

```

***

(第二次写简书...经验还是不够,希望各位dalao们多多指教!以后会更新关于android开发和java的一些demo与算法,oj ac记录主要以c++为主)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351