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模拟赛的更多相关文章

  1. 2016.10.29 NOIP模拟赛 PM 考试整理

    300分的题,只得了第三题的100分. 题目+数据:链接:http://pan.baidu.com/s/1o7P4YXs 密码:4how T1:这道题目存在着诸多的问题: 1.开始的序列是无法消除的( ...

  2. NOIP模拟赛 6.29

    2017-6-29 NOIP模拟赛 Problem 1 机器人(robot.cpp/c/pas) [题目描述] 早苗入手了最新的Gundam模型.最新款自然有着与以往不同的功能,那就是它能够自动行走, ...

  3. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  4. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  5. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  6. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  7. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

  8. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

  9. 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...

随机推荐

  1. Spring源码分析:Bean加载流程概览及配置文件读取

    很多朋友可能想看Spring源码,但是不知道应当如何入手去看,这个可以理解:Java开发者通常从事的都是Java Web的工作,对于程序员来说,一个Web项目用到Spring,只是配置一下配置文件而已 ...

  2. Java 获取系统时间

    1. Date类 Date day=new Date(); SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss&q ...

  3. tomcat学习步骤,附带打破双亲委派模型企业应用实战

    1. tomcat入门 入门模块仅做学习大纲梳理,忽略了具体操作指引. Tomcat的三种部署模式: 简单架构模型 连接器的非阻塞模式(NIO) 通道(Channel).缓冲区(Buffer).选择器 ...

  4. VMware打开虚拟机没反应的解决方案(全面汇总)

    VMware打开虚拟机无反应的解决方案(全面汇总)虚拟机没反应的解决办法大概是如下几点:一.若是第一次安装后打不开虚拟机,大致是如下两种解决方案: 1.大多数时候,虚拟机打不开都是因为防火墙拦截所致 ...

  5. SpringBoot -- 计划任务

    从Spring 3.1 开始,计划任务在Spring中的实现变得异常的简单.首先通过在配置类注解@EnableScheduling 来开启对计划任务的支持,然后再执行集合任务的方法上注解@Schedu ...

  6. BZOJ4358: permu(带撤销并查集 不删除莫队)

    题意 题目链接 Sol 感觉自己已经老的爬不动了.. 想了一会儿,大概用个不删除莫队+带撤销并查集就能搞了吧,\(n \sqrt{n} logn\)应该卡的过去 不过不删除莫队咋写来着?....跑去学 ...

  7. css-文字和图片在容器内垂直居中的简单方法

    方法一.使用line-heigh使多行文字居中或图片居中 把文字包裹在一个inline-block元素中vertical-align middle,外部元素line-heigh等于高度 <div ...

  8. json 平面转树状 child [zhuan]

    <script> /** * json格式转树状结构 * @param {json} json数据 * @param {String} id的字符串 * @param {String} 父 ...

  9. 关于ajax 传递的参数

    ajax 发送的数据,默认都是字符串,不能直接传递list(列表),或者dict(字典). 若要 传递list(列表),或者dict(字典),需要进行一些操作. list 需要进行列表序列化,在aja ...

  10. Android Studio支持Java1.8的解决方案

    Java1.8新添了一些特性,比如对lambda表达式的支持,父类推断等等,这篇文章讲述了1.8的新特性,有兴趣的同学可以点进去看看.但是由于AndroidStudio并不能直接支持Java1.8,我 ...