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. 5.C#知识点:ref和Out关键字浅谈

    首先我们要知道ref和out在C#里面是什么? 答:它们俩是C#里面的关键字. 他们俩是干啥的呢? 答:他们俩是方法参数的修饰符号,一但使用,方法定义和方法都用都要使用这个关键字,这一点是死规定. 好 ...

  2. 学习Memcached:2基本应用之控制台使用

    1.首先新建一个控制台应用. 2.将下载好需要引用的Memcached的Dll导入进来. 3.前期准备工作就结束了,其实很简单,memcache的配置使用是挺简单.下面就是写代码了. using Me ...

  3. 关于ORA-12505, TNS:listener does not currently know of SID given in connect descriptor报错问题解决办法

    1.本机tnsnames.ora 配置如下 test4= (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.1 ...

  4. Another kind of Fibonacci(矩阵)

    Another kind of Fibonacci Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  5. JavaScript高级编程——Array数组迭代(every()、filter()、foreach()、map()、some(),归并(reduce() 和reduceRight() ))

    JavaScript高级编程——Array数组迭代(every().filter().foreach().map().some(),归并(reduce() 和reduceRight() )) < ...

  6. PHP如何批量更新MYSQL中的数据

    最近项目需要用到批量更新数据库里的数据,在网上找了一下这方面的例子,觉得这个还不错,分享给大家. 在这个业务里里面涉及到了更新两张数据表,那么大家是不是会想到非常简单,马上上代码 $sql ,type ...

  7. atitit.网络文件访问协议.unc smb nfs ftp http的区别

    atitit.网络文件访问协议.unc smb nfs ftp http的区别 1. 网络文件访问协议1 2. NETBios协议  2 3. SMB(Server Message Block)2 3 ...

  8. 5,注释、分支结构、循环结构、伪“选择结构”

    注释: python使用#作为行注释符,使用三引号作为多行注释符 分支结构: if-else: a=int(input("你的成绩是:")) if a>60: print(& ...

  9. Python笔记(三):构建发布模块

      (一)     准备工作 1.   新建一个模块(名称自定义),存放要发布的模块代码. 2.   新建一个setup.py的模块(存放模块的元数据,描述相关信息). 3.   新建一个文件夹(名称 ...

  10. sklearn——数据集调用及应用

    忙了许久,总算是又想起这边还没写完呢. 那今天就写写sklearn库的一部分简单内容吧,包括数据集调用,聚类,轮廓系数等等.   自带数据集API 数据集函数 中文翻译 任务类型 数据规模 load_ ...