NOIP 2014 提高组 题解
No 1. 生活大爆炸版石头剪刀布
http://www.luogu.org/problem/show?pid=1328
这是道大水题,我都在想怎么会有人错了,没算法,直接模拟,别读错题.
][]={{,,,,}, {,,,,}, {,,,,}, {,,,,}, {,,,,}}; int n,na,nb; ],b[]; int s1,s2; int main() { ios_base::sync_with_stdio(); cin>>n>>na>>nb; ;i<=na;i++) { cin>>a[i]; } ;i<=nb;i++) { cin>>b[i]; } ,f2=; ;i<=n;i++) { f1++; f2++; ; ; ) s1++; ) s2++; } cout<<s1<<' '<<s2<<endl; ; }
No 2. 联合权值
http://www.luogu.org/problem/show?pid=1351
同样是水题,用加法结合律.
首先,距离为2的两点,必有一个节点与他们都相连.
第一个要求最大值,对于每个点,预处理出相邻的边中权值最大的两条边,枚举每个点,计算这两个值的乘积,求个最大值即可.
第二个,要求距离为2的点对的权值之和,那么,我们先确定某点对中间的那个点,设为p,并预处理出p与其相邻的点距离之和d,则与其相邻的某点q,在中心点为p的距离为二的一条路径上的权值之和为d(q,p)*d(m1,p)+d(q,p)*d(m2,p)+...+d(q,p)*d(mi,p)=d(q,p)*(d-d(q,p)) 其中mi为与p相邻的除q以外的点,共i个.
最后求和即可.
long long n; ; ]; ]; long long mx; long long ans; vector<]; ],m2[]; int main() { scanf("%lld",&n); ;i<n;i++) { long long a,b; scanf("%lld %lld",&a,&b); e[a].pb(b); e[b].pb(a); } ;i<=n;i++) { scanf("%lld",&w[i]); } ;i<=n;i++) { ;j<(long long)e[i].size();j++) { sum[i]+=w[e[i][j]]%MOD; if(w[e[i][j]]>m1[i]) { m2[i]=m1[i]; m1[i]=w[e[i][j]]; } else if(w[e[i][j]]>m2[i]) { m2[i]=w[e[i][j]]; } } } ;i<=n;i++) { mx=max(mx,m1[i]*m2[i]); } printf("%lld ",mx); ;i<=n;i++) { ;j<(long long)e[i].size();j++) { ans=ans+(w[e[i][j]])*(sum[i]-w[e[i][j]]); ans=ans%MOD; } } printf("%lld\n",ans); ; }
No 3. 飞扬的小鸟
http://www.luogu.org/problem/show?pid=1941
dp
dp
dp
其实这题真心不难
不明白为何有许多人不会做........
我们用dp(i,j)表示鸟儿飞到第i根柱子的j高度处所用的最少跳跃步数.
Obviously,不跳,摔落比较好,所以先处理它.
明显的,dp[i+1][j-y[i]]=min(dp[i+1][j-y[i]],dp[i][j]).
当鸟儿跳的时候,要是到顶了不能继续跳,所以要分个类:
1.到顶了
dp[i][m]=min(dp[i][m],dp[i][j]+1)
dp[i+1][m]=min(dp[i+1][m],dp[i][j]+1)
2.没到顶
dp[i][j+x[i]]=min(dp[i][j+x[i]],dp[i][j]+1);
dp[i+1][j+x[i]]=min(dp[i+1][j+x[i]],dp[i][j]+1);
于是就可以写程序了...
][]; ],r[]; ]; ],y[]; int ans; int n,m,k; int main() { ios_base::sync_with_stdio(); cin>>n>>m>>k; ;i<;i++) { l[i]=; r[i]=m; } ;i<n;i++) { cin>>x[i]>>y[i]; } ;i<k;i++) { int t1,t2,t3; cin>>t1>>t2>>t3; l[t1]=t2+; r[t1]=t3-; has[t1]=; } ;i<=n;i++) { has[i]+=has[i-]; } ;i<=n;i++) { ;j<=m;j++) { dp[i][j]=inf; } } ;i<=n;i++) { ;j<=m;j++) { dp[i][j]=inf; } for(int j=l[i];j<=r[i];j++) { if(dp[i][j]<inf) { ans=i; if(j>y[i]) { dp[i+][j-y[i]]=min(dp[i+][j-y[i]],dp[i][j]); } } } for(int j=l[i];j<=m;j++) { if(dp[i][j]<inf) { if(m<j+x[i]) { dp[i][m]=min(dp[i][m],dp[i][j]+); dp[i+][m]=min(dp[i+][m],dp[i][j]+); } else { dp[i][j+x[i]]=min(dp[i][j+x[i]],dp[i][j]+); dp[i+][j+x[i]]=min(dp[i+][j+x[i]],dp[i][j]+); } } } } if(ans==n) { ans=inf; for(int i=l[n];i<=r[n];i++) { ans=min(ans,dp[n][i]); } cout<<<<endl<<ans<<endl; } else { cout<<<<endl<<has[ans]<<endl; } ; }
先写day1 以后有时间再写day 2.........
NOIP 2014 提高组 题解的更多相关文章
-
NOIP 2001 提高组 题解
NOIP 2001 提高组 题解 No 1. 一元三次方程求解 https://vijos.org/p/1116 看见有人认真推导了求解公式,然后猥琐暴力过的同学们在一边偷笑~~~ 数据小 暴力枚举即 ...
-
NOIP 2000 提高组 题解
NOIP2000 提高组 题解 No 1. 进制转换 https://www.rqnoj.cn/problem/295 水题 对于n和基数r, 每次用n mod r, 把余数按照逆序排列 注意 mod ...
-
noip 2016 提高组题解
前几天写的那个纯属搞笑.(额,好吧,其实这个也不怎么正经) 就先说说day2吧: T1:这个东西应该叫做数论吧. 然而我一看到就照着样例在纸上推了大半天(然而还是没有看出来这东西是个杨辉三角) 然后就 ...
-
noip 2014 提高组 Day 2
1.无线网络发射器选址 这道题数据范围很小,就直接暴力枚举就好了.为了提高速度,就从每个有公共场所的点枚举周围在(x,y)放无线网路发射器可以增加的公共场所数量,加到一个数组里.所有公共场所都处理完了 ...
-
NOIP 2014 提高组 Day1
期望得分:100+100+50=250 实际得分:100+100+50=250 此次NOIP ZJ省一分数线:500,SD:345 https://www.luogu.org/problem/lis ...
-
NOIP 2014 提高组 Day2
期望得分:100+60+30=190 实际得分:70+60+30=160 https://www.luogu.org/problem/lists?name=&orderitem=pid& ...
-
NOIP 2008提高组第三题题解by rLq
啊啊啊啊啊啊今天已经星期三了吗 那么,来一波题解吧 本题地址http://www.luogu.org/problem/show?pid=1006 传纸条 题目描述 小渊和小轩是好朋友也是同班同学,他们 ...
-
[NOIp 1998 提高组]Probelm 2 连接多位数【2011百度实习生笔试题】
/*====================================================================== [NOIp 1998 提高组]Probelm 2 连接 ...
-
noip2010提高组题解
NOIP2010提高组题解 T1:机器翻译 题目大意:顺序输入n个数,有一个队列容量为m,遇到未出现元素入队,求入队次数. AC做法:直接开1000的队列模拟过程. T2:乌龟棋 题目大意:有长度为n ...
随机推荐
-
修复发生“由于数据移动,未能继续以 NOLOCK 方式扫描”错误的数据库
最近在系统运行中发现了一个错误,错误信息如下: 错误信息:查询A201412C20568单证信息错误 ---> System.Data.OleDb.OleDbException: 由于数据移动, ...
-
单例模式ARC和非ARC
ARC环境下的单例模式: static id _instance = nil; + (id)allocWithZone:(struct _NSZone *)zone { if (_instance = ...
-
hash简单介绍
hash也称"散列", 是一种基于映射关系的存储方式,将任意长度的二进制值输出为固定长度的较小的二进制值,这种输出的小的固定长度的值为hash值: 1. 散列技术是在关键字key与 ...
-
SharePoint 站点集和子站点数据互相读取
1.站点集中可以使用SPSite.AllWeb,然后遍历所有站点的isRootWeb,根据siteTemplate取得需要的子站点. /// <summary> /// Handles t ...
-
配置IIS提示打开目录浏览时的问题:未能从程序集“System.ServiceModel, Version=3.0.0.0”中加载类型“System.ServiceModel.Activation.HttpModule” 的解决办法
错误消息: 未能从程序集“System.ServiceModel, Version=3.0.0.0”中加载类型“System.ServiceModel.Activation.HttpModule” 的 ...
-
Perl 中 `cmd` 和system"cmd"的区别
在perl中,调用系统命令有两种形势,`cmd` 和system"cmd",他们主要的区别是`cmd`会获取返回结果,而system"cmd"会直接将结果输出到 ...
-
strace命令用法
-tt 在每行输出的前面,显示毫秒级别的时间 -T 显示每次系统调用所花费的时间 -v 对于某些相关调用,把完整的环境变量,文件stat结构等打出来. -f 跟踪目标进程,以及目标进程创建的所有子进程 ...
-
python-Django-01基础配置
参考资料地址 http://www.ziqiangxuetang.com/django/django-install.html 官方文档 一: 1先下载Django源码包,下载地址https://ww ...
-
python 怎么模拟加header(如User-Agent、Content-Type等等)
# -*- coding: cp936 -*- #python 27 #xiaodeng #python 怎么模拟加header(如User-Agent.Content-Type等等) #办法一: i ...
-
Xml中SelectSingleNode方法中的xpath用法
https://blog.csdn.net/wf520pb/article/details/2644549 最常见的XML数据类型有:Element, Attribute,Comment, Text. ...