Nescafe #29 NOIP模拟赛
Nescafe #29 NOIP模拟赛
不知道这种题发出来算不算侵权...毕竟有的题在$bz$上是权限题,但是在$vijos$似乎又有原题...如果这算是侵权的话请联系我,我会尽快删除,谢谢~
今天开始就处于一种半停课状态了.学校学习衡水,把休息时间压缩后每天又多了两节自习来写作业,但是我正好就可以来机房啦2333
因为考试时间被文化课分割成了一些散块,这里就不区分考试时的代码和赛后补题了.
T1:穿越七色虹
题意概述:给出$x$轴上的$7$个圆(圆心和半径)(只保留$x$轴以上的部分),可以将所有圆的半径同时增加一个非负数,要求$(0,0)$到$(X_0,h)$这一块矩形面积被完全覆盖。
其实这题读题稍微有点困难,不过概括之后就好理解多了。
其实这题思路挺显然的,半径越大肯定覆盖的面积越大,所以直接二分这个扩大的值,扩大之后算出每个圆可以覆盖的高度为$h$的矩形的左右端点,再做一个线段覆盖即可.这里注意一个问题:$check$时会首先把每个半径加上一个数,最后再减掉,如果是这样的做法就一定要注意不能在函数进行到一半时就$return$掉,否则这个增量就会一直留在那里啦.
# include <cstdio>
# include <iostream>
# include <cmath>
# include <algorithm> using namespace std; const double eps=0.001;
double h,x0;
double x[],rr[],l,r,mid,ans;
struct lin
{
double l,r;
}a[]; bool check (double ad)
{
double maxr=,minl=;
for (int i=;i<=;++i)
{
a[i].l=x[i]-sqrt((rr[i]+ad)*(rr[i]+ad)-h*h);
a[i].r=x[i]+sqrt((rr[i]+ad)*(rr[i]+ad)-h*h);
minl=min(minl,a[i].l);
}
if(minl>eps) return false;
for (int i=;i<=;++i)
for (int j=;j<=;++j)
if(a[j].l-maxr<=eps) maxr=max(maxr,a[j].r);
if(maxr-x0>=-eps) return true;
return false;
} int main()
{
scanf("%lf%lf",&h,&x0);
for (int i=;i<=;++i)
scanf("%lf%lf",&x[i],&rr[i]);
l=,r=sqrt(x0*x0+h*h);
ans=r+; while (r-l>=-eps)
{
mid=(l+r)/2.0;
if(check(mid))
ans=min(ans,mid),r=mid-eps;
else l=mid+eps;
}
printf("%.2lf",ans);
return ;
}
rainbow
T2:四叶草魔杖
题意概述:给出$n$个点$m$条边,每个点有一个能量值,如果是负的意味着要有这么多能量通过边运输过来,正的则为要运走这么多,每条边只要用到就会产生相应的代价,求使所有点的能量值都变为$0$所需要的最小代价.$n<=16$
看到$n$这么小的范围当然会想到搜索状压$dp$.首先所有点都被连到一起必然是合法的,但是想要合法并不需要所有点都连在一起.首先一遍状压$dp$求出每个联通块联通的最小代价,统计一下哪些联通块的权值和是$0$,把这些状态单独拿出来再进行一次状压$dp$即可,虽然复杂度不是非常科学,但是跑的还是挺快的.
# include <cstdio>
# include <iostream>
# include <cstring>
# define R register int using namespace std; const int maxn=;
const int maxz=(<<);
int n,m,h,firs[maxn];
int dp[maxz+],a[maxn],x,y,co,j;
struct edge
{
int too,nex,co;
}g[maxn*maxn];
int k[maxz+],Top=,c[maxz+]; void add (int x,int y,int co)
{
g[++h].co=co;
g[h].nex=firs[x];
firs[x]=h;
g[h].too=y;
} int main()
{
memset(dp,-,sizeof(dp));
dp[]=;
scanf("%d%d",&n,&m);
for (R i=;i<n;++i)
scanf("%d",&a[i]);
for (R i=;i<n;++i)
dp[<<i]=;
for (R i=;i<=m;++i)
{
scanf("%d%d%d",&x,&y,&co);
add(x,y,co);
add(y,x,co);
}
for (R z=;z<=(<<n)-;++z)
{
if(dp[z]==-) continue;
for (R i=;i<n;++i)
{
if((z&(<<i))==) continue;
for (R b=firs[i];b;b=g[b].nex)
{
j=g[b].too;
if(z&(<<j)) continue;
if(dp[z|(<<j)]==-)
dp[z|(<<j)]=dp[z]+g[b].co;
else
dp[z|(<<j)]=min(dp[z|(<<j)],dp[z]+g[b].co);
}
}
}
for (R i=;i<=(<<n)-;++i)
{
int s=;
if(dp[i]==-) continue;
for (R j=;j<n;++j)
if((<<j)&i) s+=a[j];
if(s==) k[++Top]=i,c[Top]=dp[i];
}
memset(dp,-,sizeof(dp));
dp[]=;
for (R i=;i<=(<<n)-;++i)
{
if(dp[i]==-) continue;
for (R j=;j<=Top;++j)
{
if(dp[ i|k[j] ]==-) dp[ i|k[j] ]=dp[i]+c[j];
else dp[ i|k[j] ]=min(dp[ i|k[j] ],dp[i]+c[j]);
}
}
if(dp[(<<n)-]==-) printf("Impossible");
else printf("%d",dp[(<<n)-]);
return ;
}
clover
T3:圣主的考验
题意概述:定义一棵合法的二叉树为:每个点的左右儿子的高度差不大于$1$,求包含$n$个节点的树有多少种可能形态.$n<=3000$.注意:如果答案大于九位就输出后九位(包括前导零),如果小于九位就原样输出.
朴素的$dp$不是很难想,但是是$n^3$的,现在在这个基础上考虑优化:(我又把$vscode$找出来啦,虽然编译的部分失效了,但是即使只是做文本编辑器也足够好看了)

这个复杂度很显然是跑不满的,尤其是第二维,因为这道题的限制卡的比较严格,所以左右子树的节点数量大致上不会相差非常多,也就是说树高趋向于$log$级别.完全二叉树的深度是所有可能中最浅的,最深的深度也不会大很多,最极端的情况是每个左儿子都比右儿子的深度大,不过直接认为是$logi$加上一个小一点的数字也是可以的.如果发现一个多维$dp$的复杂度过高而明显跑不满时,可以将自己觉得最有可能跑不满的一维直接改小,比如这里的$j$直接改成$1-10$可以得到$90$.关于输出:打表发现当$n$大于等于$36$的时候答案会大于九位...
# include <cstdio>
# include <iostream>
# define R register int
# define mod using namespace std; const int maxn=;
int n,lg[maxn];
long long dp[maxn][],s[maxn]; void init()
{
dp[][]=;
dp[][]=;
s[]=;
for (R i=;i<=;++i)
for (R j=lg[i]+;j<=lg[i]+;++j)
{
for (R l=;l<=i;++l)
{
if(i-l-<) break;
dp[i][j]+=dp[l][j-]*dp[i-l-][j-];
dp[i][j]%=mod;
dp[i][j]+=dp[l][j-]*dp[i-l-][j-];
dp[i][j]%=mod;
dp[i][j]+=dp[l][j-]*dp[i-l-][j-];
dp[i][j]%=mod;
}
s[i]+=dp[i][j];
s[i]%=mod;
}
} int main()
{
scanf("%d",&n);
for (R i=;i<=;++i)
lg[i]=lg[i/]+;
init();
while (n)
{
if(n>=) printf("%09lld\n",s[n]);
else printf("%lld\n",s[n]);
scanf("%d",&n);
}
return ;
}
domine
---shzr
Nescafe #29 NOIP模拟赛的更多相关文章
- 2016.10.29 NOIP模拟赛 PM 考试整理
300分的题,只得了第三题的100分. 题目+数据:链接:http://pan.baidu.com/s/1o7P4YXs 密码:4how T1:这道题目存在着诸多的问题: 1.开始的序列是无法消除的( ...
- NOIP模拟赛 6.29
2017-6-29 NOIP模拟赛 Problem 1 机器人(robot.cpp/c/pas) [题目描述] 早苗入手了最新的Gundam模型.最新款自然有着与以往不同的功能,那就是它能够自动行走, ...
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程
数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...
- 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...
- 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...
- 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...
随机推荐
- WPF--模板选择
典型的,把模板关联到一块特定的数据上,不过通常希望动态的确定使用哪个模板---既可以基于一个属性值,也可以是一个全局状态.当真正需要大规模替换模板时,也可以使用DataTempl ...
- C#中利用LightningChart绘制曲线图表
最近在做一个“基于C#语言的电炉温控制软件设计”的设计,我在大学并不是专业学习C#语言编程的,对C#的学习研究完全是处于兴趣,所以编程技术也不是很厉害,遇到问题多参照网络上的开源码. 这不,在做这个课 ...
- Java - fail-fast机制
Java提高篇(三四)-----fail-fast机制 在JDK的Collection中我们时常会看到类似于这样的话: 例如,ArrayList: 注意,迭代器的快速失败行为无法得到保证,因为一般来说 ...
- Java生成代码(字节码)
一.方式 代码生成器 & IDE 编译时代码生成: Pluggable Annotation Processing API 运行时代码生成: Compiler API 运行时生成字节码: cg ...
- apicloud 自定义模块引用aar
apicloud 引入aar包,如果使用apicloud自定义模块的话,如果是一般的jar包,我们需要把jar down到本地然后添加到module的libs中就可以了(不要想着用远程地址了,既然用a ...
- python正则表达式贪婪与非贪婪模式
之前做程序的时候看到过正则表达式的贪婪与非贪婪模式,今天用的时候就想不起来了,现在这里总结一下,以备自己以后用到注意. 1.什么是正则表达式的贪婪与非贪婪匹配 如:String str="a ...
- JavaScript小细节点罗列(2)
break 语句和 continue 语句 break语句和continue语句都具有跳转作用,可以让代码不按既有的顺序执行. break语句用于跳出代码块或循环. var i = 0; while( ...
- 图像阈值化-threshold、adaptivethreshold
在图像处理中阈值化操作,从一副图像中利用阈值分割出我们需要的物体部分(当然这里的物体可以是一部分或者整体).这样的图像分割方法是基于图像中物体与背景之间的灰度差异,而且此分割属于像素级的分割.open ...
- Nodejs编译Native Code:使用C++构建工具npm
Nodejs的很多NPM包需要本地编译,通常是C++写的代码,例如图像处理模块等. 这是如果生产环境没有安装Visual Studio 2015等开发工具,通常会编译失败,发现了一个npm专门干这事儿 ...
- 学习git踩坑之路
第一次使用git: 1.使用CentOS Linux release 7.3.1611 (Core),内核版本3.10.0-514.el7.x86_64 2.安装git: root权限运行:yum ...