noip2003提高组题解
这一年的前三题虽然难度不高,但是第二题极为繁琐,想在考场上用较短的时间拿到第二题的分数难上加难。所以必须要调整策略,争取拿其他三题的分数。第四题是比较普通的搜索题,分数比较好拿,但是很容易想成树形DP,就只能拿30~50分。
第一题:神经网络
模拟
有几个注意点:
- 输入层(即第一层)的结点的U(阈值)是没有用的;
- 题目说输出「最后状态非零的输出层神经元状态」,但实际上输出的是状态大于0的值。
由于没有注意到神经元只有在兴奋状态时才会向下传送信号,所以WA了1次。
第二题:侦探推理
模拟+枚举
我用的是比较笨拙的枚举策略:枚举哪些人说的是真话,哪些人说的是假话。
但更好的策略是:枚举谁是凶手。
繁琐但不难,注意几个点:
- 凶手只有一个。那么当只有一个人且根据其话语无法推出是不是凶手时,其必然是凶手;
- 程序无法确定出凶手时可能是Cannot Determine,也可能是Impossible,需要根据具体情境进行特殊处理。
花了很久才AC,与我的解题策略的选择有莫大的关系。
第三题:加分二叉树
动态规划
很可惜做这道题在最开始的时候就想错了,用贪心写了一下,结果只过了1个点。应该说很多题目都是看似可以用贪心做但其实应该用动规(01背包、石子合并等),这也是以后做题时的一个注意点。
首先题目要求构造的树的中序遍历要有序,其实也就是由序列(1,2,…,n)构造出一棵二叉排序树:选择某个数字为根,把比它小的数字安排在它的左子树,把比它大的数安排在它的右子树,递归进行。
问题就是如何选择根?
由题意可以看出,一个数字的层次越深,它对整个二叉树的加分的「贡献」就越大,所以我想到的是贪心策略:将权值大的结点尽量安排在树的叶端,即把权值最小的结点作为根。
这样的贪心策略看似正确而且也符合样例数据,但其实是错误的。根据上面所述,如果按照贪心策略构建出这样的树,那么最理想的状态是结点的权值与深度应该成正比(但是为了满足BST的性质需要进行调整)。如果每次将权值最小的结点作为根,往往达不到这样的状态。比如:结点1,2,…,n对应的权值为99,2,2,…,2,则权值最大的结点1会被安排在权值最小的结点2的左子树而且成为叶子结点,这样分配明显是很不合理的。
正确的策略应该是采用动态规划,枚举需要用哪个结点作为根。
f(l, r) 表示将区间 [l, r] 构建成加分二叉树所得的最大加分(区间 [l, r] 表示结点编号),则
f(l, r) = max{ f(l, j) * f(j+1, r) + w(j), l<=j<=r}
边界条件:f(l, r) = 1 (l > r)
时间复杂度:O(n^3)
第四题:传染病控制
搜索
一开始以为是动规,但实际上有后效性。
按层进行搜索,枚举哪一条边需要被截断,将已被阻断的子树上的结点做标记,然后搜索下一层。
有一个普通的剪枝:如果当前感染人数大于已找到的最小人数则回溯。
但是很奇怪的是只有一个点过不了,而且答案只和标准答案相差1,实在无力调试,所以就针对特殊情况打表骗了个AC。
经验教训:
- 要总结平时遇到的容易想错算法的题目(动规想成贪心、搜索想成动规),寻找其特点与规律;
- 多做题目就会对各种算法适用的题型有更清晰的认识和更深刻的理解,帮助解题;
- 不能轻视模拟题,有些模拟题题目较复杂,要有提炼题目的能力。
noip2003提高组题解的更多相关文章
- noip2010提高组题解
NOIP2010提高组题解 T1:机器翻译 题目大意:顺序输入n个数,有一个队列容量为m,遇到未出现元素入队,求入队次数. AC做法:直接开1000的队列模拟过程. T2:乌龟棋 题目大意:有长度为n ...
- NOIP 2014 提高组 题解
NOIP 2014 提高组 题解 No 1. 生活大爆炸版石头剪刀布 http://www.luogu.org/problem/show?pid=1328 这是道大水题,我都在想怎么会有人错了,没算法 ...
- 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 ...
- 【NOIP2018】提高组题解
[NOIP2018]提高组题解 其实就是把写过的打个包而已 道路铺设 货币系统 赛道修建 旅行 咕咕咕 咕咕咕
- 题解【洛谷P1038/CJOJ1707】[NOIP2003提高组]神经网络
[NOIP2003]神经网络 Description 问题背景:人工神经网络( Artificial Neural Network )是一种新兴的具有自我学习能力的计算系统,在模式识别.函数逼近及贷款 ...
- NOIP2003[提高组] 加分二叉树 题解
题意 给出一个有n个节点的二叉树的中序遍历,以当前节点为根的树的分数等于左节点分数* 右节点分数+根节点分数,叶子节点的分数等于它本身,求最大分数,以及分数最大的树的先序遍历 一道区间dp题,因为要求 ...
- noip2009提高组题解
NOIP2009题解 T1:潜伏者 题目大意:给出一段密文和破译后的明文,一个字母对应一个密文字母,要求破译一段密文,如果有矛盾或有未出现密文无法破译输出failed,否则输出明文. 思路:纯模拟题 ...
- noip2008提高组题解
第一题:笨小猴 模拟 第二题:火柴棒等式 搜索 深搜不用说,确定出两个加数然后判断能否拼出等式. 枚举确实不太好搞,因为枚举范围不确定,太大了容易超时,太小了容易漏解.不过这题的数据貌似很温和,我 ...
随机推荐
- 《云大课程助手》Android刷课工具来袭
云大课程助手(Android)谨以此app纪念我这四年的大学生活.希望大家用的愉快. 下载地址:http://zhushou.360.cn/detail/index/soft_id/922292注:已 ...
- idea从vcs引入maven项目报错
一.问题 用idea从cvs上check out的maven项目,打开后,发现依赖的jar包都有红色下划线.检查本地的maven库中有对应的包,那就是依赖有问题,idea没有在本地找到对应的包. 二. ...
- POJ2104 k-th number 划分树
又是不带修改的区间第k大,这次用的是一个不同的方法,划分树,划分树感觉上是模拟了快速排序的过程,依照pivot不断地往下划分,然后每一层多存一个toleft[i]数组,就可以知道在这一层里从0到i里有 ...
- hdu 2837 Calculation
公式:a^b%p=a^(b%phi(p)+phi(p))%p b>=phi(p) #include<iostream> #include<stdio.h> #incl ...
- C#中的文件操作
在.NET Framework 中进行的所有输入和输出工作都要用到流(stream) 有两种类型的流: 输出流:当向某些外部目标写入数据时,就要用到输出流(将数据写入到文件中). 输入流:用于将数据读 ...
- TVM 下载监控
iftop -n -i em1 -F 218.26.188.220/32 到10.10.81.23上用上面的语句看山西的流量. 到/opt/data/log/下看日志 到/opt/data/tvmca ...
- windows下eclipse远程连接hadoop错误“Exception in thread"main"java.io.IOException: Call to Master.Hadoop/172.20.145.22:9000 failed ”
在VMware虚拟机下搭建了hadoop集群,ubuntu-12.04,一台master,三台slave.hadoop-0.20.2版本.在 master机器上利用eclipse-3.3连接hadoo ...
- 李洪强iOS开发之Foundation框架—集合
Foundation框架—集合 一.NSArray和NSMutableArray (一)NSArray不可变数组 (1)NSArray的基本介绍 NSArray是OC中使用的数组,是面向对象的,以面向 ...
- lintcode 中等题:Submatrix sum is 0 和为零的子矩阵
和为零的子矩阵 给定一个整数矩阵,请找出一个子矩阵,使得其数字之和等于0.输出答案时,请返回左上数字和右下数字的坐标. 样例 给定矩阵 [ [1 ,5 ,7], [3 ,7 ,-8], [4 ,-8 ...
- lintcode 中等题: Implement Trie
题目 Implement Trie Implement a trie with insert, search, and startsWith methods. 样例 注意 You may assu ...