NOIp 0904 出题报告
T1 huajitree
纯模拟,把S拆成二进制查一下有多少个1,然后把这个数和N*M求一下gcd,除一下输出就好了。说求期望值可能对新高一不太友好….
//huajitree //2016.8.22 //by Cydiater #include <iostream> #include <cstdio> #include <cstdlib> #include <queue> #include <map> #include <cstring> #include <string> #include <algorithm> #include <cmath> #include <ctime> #include <iomanip> using namespace std; #define FILE "huajitree" #define ll long long #define up(i,j,n) for(int i=j;i<=n;i++) #define down(i,j,n) for(int i=j;i>=n;i--) const int oo=0x3f3f3f3f; inline ll read(){ ,f=; ;ch=getchar();} +ch-';ch=getchar();} return x*f; } ll S,ans=,N,M; namespace solution{ inline ll gcd(ll a,ll b){?a:gcd(b,a%b);} void init(){ N=read();M=read();S=read(); ans=; } void slove(){ ){ans+=S%;S/=;} } void output(){ ll d=gcd(ans,N*M); )cout<<ans/d<<'/'<<N*M/d; "); } } int main(){ freopen(FILE".in","r",stdin); freopen(FILE".out","w",stdout); using namespace solution; init(); slove(); output(); ; }
T2 pack
起名叫pack是为了衔接剧情QAQ,60分裸的DP,会DP就应该会,如果学过DP这个的60分没写出来就应该考虑补一下DP了。
所有数据都是随机的..所以加上一些奇淫技巧也许能暴力A掉?
给出状态转移方程:
首先把h和v的前缀和都搞出来
//NOIp by Cydiater right //by Cydiater //2016.8.24 #include <iostream> #include <cstdio> #include <cstring> #include <string> #include <algorithm> #include <queue> #include <map> #include <ctime> #include <cstdlib> #include <iomanip> #include <cmath> using namespace std; #define ll long long #define up(i,j,n) for(int i=j;i<=n;i++) #define down(i,j,n) for(int i=j;i>=n;i--) #define FILE "pack" ; const int oo=0x3f3f3f3f; inline ll read(){ ,f=; ;ch=getchar();} +ch-';ch=getchar();} return x*f; } ll N,sum[MAXN],h[MAXN],q[MAXN],head,tail,f[MAXN]; namespace solution{ void init(){ N=read(); memset(sum,,sizeof(sum)); memset(h,,sizeof(h)); memset(f,,sizeof(f)); up(i,,N){ sum[i]=sum[i-]+read(); h[i]=h[i-]+read(); } } inline double col(int x,int y){ double t1=f[y]-f[x]; double t2=sum[y]-sum[x]; return t1/t2; } void slove(){ head=;tail=;q[++tail]=; up(i,,N){ ])<h[i])head++; f[i]=f[q[head]]+(sum[i]-sum[q[head]])*h[i]; ],q[tail])>col(q[tail],i))tail--; q[++tail]=i; } } void output(){ cout<<f[N]<<endl; } } int main(){ freopen(FILE".in","r",stdin); freopen(FILE".out","w",stdout); using namespace solution; init(); slove(); output(); ; }
T3 block
我太弱啦出不了第三题,这是BZOJ上的一道题,所以说这个的题解你随便一搜成片的都是,我简单废话一下,本题所需要的数据结构就是线段树,简单的说就是用线段树维护连通性,高二的各位神犇你们说良心不良心呀。
怎么用线段树维护连通性呢?
反正我是用一个线段树里维护6个值,分别是
左上到左下的连通性
左上到右下的连通性
左上到右上的连通性
左下到右下的连通性
左下到右上的连通性
右上到右下的连通性
维护四个值好像也没什么问题,具体的自己思考
然后合并什么的就很好(ma)搞(fan)了
具体的实现可以参考我180行的代码,虽然写的很丑..
COGS上有一个神犇90行就解决了,你们也可以去看看他的代码
//BZOJ 1018 //by Cydiater //2016.8.24 #include <iostream> #include <cstring> #include <cstdio> #include <cstdlib> #include <string> #include <ctime> #include <cmath> #include <queue> #include <map> #include <iomanip> #include <algorithm> using namespace std; #define FILE "block" #define ll long long #define up(i,j,n) for(int i=j;i<=n;i++) #define down(i,j,n) for(int i=j;i>=n;i--) ; const int oo=0x3f3f3f3f; inline int read(){ ,f=; ;ch=getchar();} +ch-';ch=getchar();} return x*f; } struct Tree{ bool luru;/*left up to right up*/ bool ldrd;/*left down to right down*/ bool lurd;/*left up to right down*/ bool ldru;/*left down to right up*/ bool luld;/*left up ro left down*/ bool rurd;/*right up to right down*/ }t[MAXN<<]; ][MAXN],pipe[MAXN]; ; ]; namespace solution{ Tree reload(Tree a,Tree b,bool upedge,bool downedge){ Tree c; c.luld=a.luld;c.rurd=b.rurd; c.luru=(a.luru&upedge&b.luru)|(a.lurd&downedge&b.ldru); c.ldrd=(a.ldrd&downedge&b.ldrd)|(a.ldru&upedge&b.lurd); c.lurd=(c.luru&c.rurd)|(c.luld&c.ldrd)|(a.luru&upedge&b.lurd)|(a.lurd&downedge&b.ldrd); c.ldru=(c.ldrd&c.rurd)|(c.luld&c.luru)|(a.ldrd&downedge&b.ldru)|(a.ldru&upedge&b.luru); c.luld=c.luld|(c.lurd&c.ldrd)|(c.ldru&c.luru)|(a.luru&upedge&b.luld&downedge&a.ldrd); c.rurd=c.rurd|(c.lurd&c.luru)|(c.ldru&c.ldrd)|(b.luru&upedge&a.rurd&downedge&b.ldrd); return c; } void build(int leftt,int rightt,int root){ if(leftt==rightt){ t[root].luru=t[root].ldrd=; t[root].lurd=t[root].ldru=t[root].luld=t[root].rurd=; return; } ; t[root].luru=t[root].ldrd=t[root].lurd=t[root].ldru=t[root].luld=t[root].rurd=; build(leftt,mid,root<<); build(mid+,rightt,root<<|); } void updata1(int leftt,int rightt,int root){ if(leftt>k||rightt<k) return; if(leftt==k&&rightt==k){ t[root].luld=t[root].rurd=t[root].lurd=t[root].ldru=v; return; } ; updata1(leftt,mid,root<<); updata1(mid+,rightt,root<<|); t[root]=reload(t[root<<],t[root<<|],toright[][mid],toright[][mid]); } void updata2(int leftt,int rightt,int root){ if(leftt>k||rightt<k) return; if(leftt==k&&rightt==k) return; ; updata2(leftt,mid,root<<); updata2(mid+,rightt,root<<|); t[root]=reload(t[root<<],t[root<<|],toright[][mid],toright[][mid]); } Tree get(int leftt,int rightt,int root){ Tree a,b,c; if(leftt>=limleft&&rightt<=limright) return t[root]; ; <=limleft) ,rightt,root<<|); ); else{ a=); b=,rightt,root<<|); c=reload(a,b,toright[][mid],toright[][mid]); } return c; } void slove(){ memset(toright,,sizeof(toright)); while(scanf("%s",s)!=EOF){ ]=='E')break; ]=='O'){ c1=read();r1=read();c2=read();r2=read(); if(r1==r2&&c1!=c2){ k=r1;v=;pipe[k]=; updata1(,N,); } if(r1!=r2&&c1==c2){ r1=min(r1,r2);k=r1; toright[c1-][r1]=; updata2(,N,); } } ]=='C'){ c1=read();r1=read();c2=read();r2=read(); if(r1>r2){ swap(r1,r2); swap(c1,c2); }/*make sure that r1<=r2*/ if(r1==r2&&c1!=c2){ k=r1;v=;pipe[k]=; updata1(,N,); } if(r1!=r2&&c1==c2){ r1=min(r1,r2); toright[c1-][r1]=;k=r1; updata2(,N,); } } ]=='A'){ c1=read();r1=read();c2=read();r2=read(); if(c1==c2&&r1==r2){puts("Y");continue;} if(r1>r2){ swap(r1,r2); swap(c1,c2); }/*make sure that r1<=r2*/ limleft=;limright=r1;Tree go_left=,N,); limleft=r1;limright=r2;Tree go_mid=,N,); limleft=r2;limright=N;Tree go_right=,N,); if(r1==r2&&c1!=c2){ if(go_left.rurd||go_right.luld||go_mid.luld)puts("Y"); else puts("N"); } if(r1!=r2&&c1==c2){ ){ if((go_left.rurd&go_mid.ldrd&go_right.luld)||go_mid.luru||(go_left.rurd&go_mid.ldru)||(go_right.luld&go_mid.lurd))puts("Y"); else puts("N"); }else{ if((go_left.rurd&go_mid.luru&go_right.luld)||go_mid.ldrd||(go_left.rurd&go_mid.lurd)||(go_right.luld&go_mid.ldru))puts("Y"); else puts("N"); } } if(r1!=r2&&c1!=c2){ ){/*left up to right down*/ if((go_left.rurd&go_mid.ldrd)||go_mid.lurd||(go_left.rurd&go_mid.ldru&go_right.luld)||(go_mid.luru&go_right.luld))puts("Y"); else puts("N"); }else{/*left down to right up*/ if((go_left.rurd&go_mid.luru)||go_mid.ldru||(go_left.rurd&go_mid.lurd&go_right.luld)||(go_mid.ldrd&go_right.luld))puts("Y"); else puts("N"); } } } } } } int main(){ freopen(FILE".in","r",stdin); freopen(FILE".out","w",stdout); using namespace solution; N=read(); build(,N,); slove(); ; }
小结
这套题对新高一可能不太友好,但是这些知识点全都是在NOIp范围内的,可能一些比较偏?但是一些零碎的东西还是要学的。个人以为NOIp2016想进top5这套题应该要拿到230分以上吧..
没什么可说的了,感谢滑稽大师cdc友情出演。
NOIp 0904 出题报告的更多相关文章
- NOIP 2017 解题报告
---恢复内容开始--- NOIP 2017 的题真的很难啊,怪不得当年我这个萌新爆零了(当然现在也是萌新)越学越觉得自己什么都不会. 想要成为强者要把这些好题都弄懂弄透 至少现在6道题我都比较陌生 ...
- NOIP 2000解题报告
题目简单,思路很快就有,关键是代码实现能力,大概3个多小时完成.第一题:题目大意:将一个10进制数N转换成-B进制数 (负进制转换):B<=20, N(-32768<=N<=3276 ...
- NOIP 2001解题报告
第一题: 有形如:ax3+bx2+cx+d=0 这样的一个一元三次方程.给出该方程中各项的系数(a,b,c,d 均为实数),并约定该方程存在三个不同实根(根的范围在-100至100之间),且根与 ...
- NOIP 2003解题报告
第一题(神经网络): 题目大意,给出一些点,每个点都有2个值,c和u,给出一些有向边,权值为w.入度为0的点的c已知,其它点的c未知,每个入度不为0的点node的c等于sum(c[k]*w[k][no ...
- NOIP 2006 解题报告
第一题: 在Mars星球上,每个Mars人都随身佩带着一串能量项链.在项链上有N颗能量珠.能量珠是一颗有头标记与尾标记的珠子,这些标记对应着某个正整数.并且,对于相邻的两颗珠子,前一颗珠子的尾标记一定 ...
- Luogu P1082 同余方程(NOIP 2012) 题解报告
题目传送门 [题目大意] 求关于x的同余方程 ax≡1(mod b)的最小整数解. [思路分析] 由同余方程的有关知识可得,ax≡1(mod b)可以化为ax+by=1,此方程有解当且仅当gcd(a, ...
- [日常] NOIp 2018 滚粗记
考试前预感到自己会滚大粗 然后发现确实滚了个大粗 ==== €€£ WARNING ==== 因为是后补的所以更新速度比较慢 最后决定把半成品扔出来 预计本周末放假会更完吧 2019.2.25 upd ...
- NOIP2018退役祭
退役感受 在写下这个标题的时候,我的心情是复杂的,无非就是感觉像对一位将要赶往战场的士兵说:"你的战争已经输掉了." 退役了,没有什么好说的.无论再怎么抱怨这题出的真烂也无法改变了 ...
- NOIP 2018 普及组 解题报告
目录 标题统计 题目链接 思路 代码 龙虎斗 题目链接: 思路 代码 摆渡车 题目链接: 思路 对称二叉树 题目链接 思路: 先来解释一下为毛现在才来发解题报告: 其实博主是参加过NOIP 2018普 ...
随机推荐
- Linux之我见
Linux哲学之美 linux就像是一个哲学的最佳实践.如果非要对它评价,我真的不知道该怎么赞叹,我只能自豪的说着:“linux的美丽简直让人沉醉.” 我只能说是我处在linux学习的修炼之路上的一个 ...
- 网页样式——各种炫酷效果持续更新ing...
1.evanyou效果-彩带的实现,效果如下 注:这个主要用的是Canvas画布实现的,点击背景绘制新的图形,代码如下: /*Html代码:*/ <canvas id=">< ...
- Uwp Windows10获取设备位置(经纬度)
先在Package.appxmanifest中配置位置权限 2. 创建LocationManager类 using System; using System.Collections.Generic; ...
- (02)javascript属性
私有属性(私有变量和私有方法) 实例属性(实例变量和实例方法) 静态属性(静态变量和静态方法) <!DOCTYPE html> <html lang="en"&g ...
- Dubbo系列(2)_RPC介绍
一.本文目的 主要介绍RPC的一些概念和应用. 二.为什么要介绍RPC DUBBO是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,是阿里巴巴SOA服务化治 ...
- CodeForces 450B 矩阵
A - Jzzhu and Sequences Time Limit:1000MS Memory Limit:262144KB 64bit IO Format:%I64d & ...
- 【转】oracle数据库开发的一些经验积累
1.不安装Oracle客户连接Oracle 8的方法 请将以下文件拷贝到运行文件所在目录 一.ODBC动态库 : ctl3d32.dll msvcrt40.dll odbc16gt.dll odbc ...
- bootstrap fileinput-上传回调
通过第三分jquery重新绑定一个重新加载事件 $("#file-4").on("fileuploaded", function(event, data, pr ...
- quartz介绍
Quartz 是一个开源的作业调度框架,它完全由 Java 写成,并设计用于 J2SE 和 J2EE 应用中.它提供了巨大的灵活性而不牺牲简单性.你能够用它来为执行一个作业而创建简单的或复杂的调度.本 ...
- 18 BufferedReader使用方法
生成BufferedReader对象的方法: BufferedReader in=new BufferedReader(new FileReader("foo.in")); imp ...