test20190802 夏令营NOIP训练18
今天的题很有难度啊。然而我10:40才看题……
高一学堂
在美丽的中山纪念中学里面,有一座高一学堂。所谓山不在高,有仙则名;水不在深,有龙则灵。高一学堂,因为有了yxr,就成了现在这个样子 = =。
由于yxr 的语言太过雷人,每次他发微往往都会有一石激起千层浪的效果,具体就是所有关注他的人都会转发,同时@他,接着关注这些人的人也会转发,同时@他关注的人(注意转发内容本身会有@yxr),以此类推。这样导致每次yxr 发微博都会被@上兆次,而yxr 又特别喜欢发,sina 支持不了如此庞大的数据量,特出规定,每次转发时,@的人不能超过K 人,好友在转发时如果超过了,就把最早那人删掉。现在yxr 刚发了一条微博“求满分”,他想知道每个与他有联系的人分别会被@多少次。
输入格式:
输入第一行有三个整数,N,K,表示人数和K。
接下来N-1 行,每行有2 个整数a,b,表示a 和b 有关注关系。
输入给出一棵以1 号点为根的树,一号点代表yxr,对于任意一个点,他的儿子都关注他。
输出格式:
输出有N 行,每行有一个整数,这个人会被@多少次。
样例输入:
5 2
1 2
2 3
2 4
4 5
样例输出:
3
3
0
1
0
数据范围:
对于30%的数据,N≤100;
对于60%的数据,N≤2000,K≤100;
对于100%的数据,N≤100000, K≤N。
时间限制:
1S
空间限制:
256M
题解
求一个点向下至多k层的子树节点个数。
可以按深度排序后,主席树+dfs序解决,时空复杂度\(O(n \log n)\)
当然还有更简单的做法,用子树大小减去深度大于k的即可。而这个只需要在每个节点的时候把它的k+1级祖先的记录数组+1,向上更新记录数组即可。类似树上差分。
时间复杂度\(O(n)\)。
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int MAXN = 1e5 + 10;
const LL MOD = 1e9 + 7;
inline LL in()
{
LL x = 0, flag = 1; char ch = getchar();
while (ch < '0' || ch > '9') { if (ch == '-') flag = -1; ch = getchar(); }
while (ch >= '0' && ch <= '9') x = (x << 3) + (x << 1) + (ch ^ 48), ch = getchar();
return x * flag;
}
int n, m;
int head[MAXN], nume;
struct Adj { int nex, to; LL w; } adj[MAXN << 1];
void addedge(int from, int to, LL w)
{
adj[++ nume] = (Adj) { head[from], to, w };
head[from] = nume ;
}
int dep[MAXN], rec[MAXN];
LL tag[MAXN];
void mark(int u)
{
if (dep[u] - m >= 1) tag[rec[dep[u] - m - 1]] --;
else tag[0] --;
tag[rec[dep[u] - 1]] ++;
}
void DFS(int u, int fa)
{
dep[u] = dep[fa] + 1;
rec[dep[u]] = u;
mark(u);
for (int i = head[u]; i; i = adj[i].nex)
{
int v = adj[i].to;
if (v == fa) continue;
DFS(v, u);
}
}
void DFS2(int u, int fa)
{
for (int i = head[u]; i; i = adj[i].nex)
{
int v = adj[i].to;
if (v == fa) continue;
DFS2(v, u);
tag[u] += tag[v];
}
}
int main()
{
n = in(), m = in();
for (int i = 1; i < n; ++ i)
{
int u = in(), v = in();
addedge(u, v, 0);
addedge(v, u, 0);
}
DFS(1, 0);
DFS2(1, 0);
for (int i = 1; i <= n; ++ i) printf("%lld\n", tag[i]);
return 0;
}
高二学堂
在美丽的中山纪念中学中,有座高二学堂,同样也是因为一个人,让它们变成了现在这个样子~那就是我们伟大的级主任。
因为他,我们又迎来了一个木有电影,只有对答案的段考日;又迎来了一个不是大礼拜,而是小礼拜的周末。因为是小礼拜,同学们都不回家,所以干脆就
回到宿舍去玩牌了。而由于三国杀太out 了,所以现在他们都玩四国杀。
四国杀(说白了就是扑克牌~)是Wayne 发明的,源于他对升级、斗地主、锄大地等等玩法都感到厌倦了。于是他提出了这个新的玩法:
Wayne 有一副加强版的扑克牌,强大到任意取一个自然数x,在牌堆里都恰有4 张数值为x 的牌。每次,Wayne 随机生成两个正整数n 和k,然后在牌堆里选取不超过k 张牌,使得牌面数字之和恰为n。已知Wayne 玩了若干盘,每盘都算出了对应的方案数,他想请你也算出各盘方案数,以验算他的结果是否正确。
结果可能比较大,你只需要求出方案数mod 1000000009 的值即可。
输入格式:
输入文件包含不超过10 组数据。
每行包含两个整数,表示上文中的n 和k。
输入数据以两个0 表示结束。
输出格式:
输出文件中,每组数据输出一行,为对应的方案数。
样例输入:
2 1
2 2
2 3
50 5
0 0
样例输出:
4
10
10
1823966
数据范围:
对于10%的数据,k=1;
对于20%的数据,n≤10,k≤4;
对于40%的数据,n≤1000;
对于60%的数据,n≤100000;
对于另外20%的数据,只有1 组数据;
对于100%的数据,n≤10^9,k≤10。
时间限制:
1S
空间限制:
256M
题解
这边的人怎么一拿到题就开始插多项式或者BM……
BM是可以过这道题的,你只需要写一个\(O(n^3)\)的背包DP就可以用BM了……留坑。
正常向的做法
因为限制有两维,考虑选牌的几何意义。
我们把选的牌按照大小排好,然后以高度为横轴,以张数为纵轴来考虑。把它们堆成一个上小下大的阶梯状。
然后我们来按高度DP。
那么考虑状态\(f(i,j,k)\)表示和为\(i\),当前这个高度上堆的张数是\(j\),限制为\(k\)的时候的方案数。具体高度是什么不重要,所以不需要它的状态。
然后转移注意阶梯落差不能超过4,以及出现落差的时候乘以一个组合数就行了。
然后发现转移是固定的,可以矩阵快速幂优化。
高三楼
参观完各种饭堂,学校还有什么著名的景点呢?当然是教室了,此时此刻我们来到了高三楼。你会发现高三楼门口会有以身份认证系统,这东西还有着一段疼人的历史。
每年的九月到来,高三的童鞋大多不习惯学校的作息时间,有人迟到的情况在所难免,2013 届的moreD 同志作为当年的纪检部部长,创造了一种十分厉害的身份认证系统。他会给每位童鞋的饭卡加上一个电子认证信息:一个n*n的矩阵,其中,每行每列都有两个特殊的点。moreD 同志设计的身份认证系统会把这些矩阵读进来,并且对此进行解析,由于每个同学都带有独特的矩阵,系统就可以在0.00001s 内认证出童鞋的身份。这样迟到的童鞋被登记的速度就会加快(刷卡嘛),大家上课的时间就不会耽误了,简单、快捷、方便统计。这一切都要感谢moreD 神牛。
但是,有一个IQ 超高的,经常迟到的童鞋,为了不扣分,他破解了moreD的身份认证系统,并对自己的认证信息做了更改。moreD 得知这个消息后立即对此等不良bug 进行改进。
他发现对于一些矩阵,只要把与之“重复”的矩阵取出,假身份认证信息的制造率会降低很多。
“重复”的定义为矩阵a,通过任意次行列变换,变成了矩阵b,矩阵a,b就视为重复。
例如:对于3*3 的矩阵,其中矩阵a 与矩阵b 被视为“重复”矩阵。
moreD 想知道对于一个n,可以有多少种不“重复”的矩阵,来填写不同学生的信息,moreD 忙着更改身份认证系统,这个艰巨的任务就交给你了,你只需要输出答案mod 100000007 的值就可以了,因为高一的学生可没有这么多。
输入格式:
第一行,一个整数t,表示数据组数。
接下来t 行,每行一个整数n,表示一组数据。
输出格式:
T 行,每行一个整数,表示方案数。由于答案可能很大,只需要输出方案数mod 100,000,007 的值就可以了。
样例输入:
3
2
3
4
样例输出:
1
1
2
数据范围:
对于10%的数据 N≤5;
对于50%的数据 N≤150;
对于100%的数据T≤5 N≤2,000。
时间限制:
1S
空间限制:
256M
题解
把行列建出二分图,那么二分图就是对应了很多的环。行列变换只是把环上节点的编号换了一下。
所以环的个数或大小不同,对应的矩阵就不同,所以要求的就是类似自然数拆分的方案数。
注意二分图只有偶环,并且这道题里面没有长度为2的环。
#include <cstdio>
const int N = 2e3 + 5, Mod = 1e8 + 7;
int T, dp[N], n;
int main() {
dp[0] = 1;
for (int i = 2; i <= 2000; ++i)
for (int j = i; j <= 2000; ++j)
dp[j] = 1LL * (dp[j] + dp[j - i]) % Mod;
for (scanf("%d", &T); T--; scanf("%d", &n), printf("%d\n", dp[n]));
return 0;
}
test20190802 夏令营NOIP训练18的更多相关文章
- test20190805 夏令营NOIP训练20
100+0+0=100,由于第二题写挂rank 1就没了 山 xyz现在站在一个斜坡面前 这个斜坡上依次排布这n座山峰,xyz打算爬上其中的一座 因为xyz体力不好,所以他只能爬上最矮的一座山 又因为 ...
- test20190803 夏令营NOIP训练19
60+100+0=160 贪婪大陆 面对蚂蚁们的疯狂进攻,小FF的Tower defence宣告失败--人类被蚂蚁们逼到了Greed Island上的一个海湾.现在,小FF的后方是一望无际的大海, 前 ...
- test20190731 夏令营NOIP训练16
0+90+0=90.我只挑了T2做. 连接格点 有一个M行N列的点阵,相邻两点可以相连.一条纵向的连线花费一个单位,一条横向的连线花费两个单位.某些点之间已经有连线了,试问至少还需要花费多少个单位才能 ...
- test20190729 夏令营NOIP训练14
40+100+0=140. 基因光线 黑大帅统治古古怪界后,一直在玩一种很奇葩的游戏.在一个二维平面上,他先复制了n个小A,把他们放在不同的位置,然后射出一条ax+by+c=0的基因光线,宽度为d,即 ...
- 夏令营501-511NOIP训练18——高二学堂
传送门:QAQQAQ 题意:给你一个数$n$,把它拆分成至多$k$个正整数,使得这些数的和等于$n$且每一个正整数的个数不能超过$4$ 拆分的顺序是无序的,但取出每一个数方案是不同的(例如我要拆$1$ ...
- 夏令营501-511NOIP训练18——高三楼
传送门:QAQQAQ 题意:定义矩阵A与矩阵B重复,当且仅当A可以通过任意次行列交换得到B,例如下图A,B即为合法矩阵 现求对于$n*n$的矩阵有多少个不重复的矩阵 数据范围: 对于10%的数据 N≤ ...
- XJOI 夏令营501-511NOIP训练18 高二学堂
在美丽的中山纪念中学中,有座高二学堂,同样也是因为一个人,让它们变 成了现在这个样子~那就是我们伟大的级主任.因为他,我们又迎来了一个木有电影,只有对答案的段考日:又迎来了一个不是大礼拜,而是小礼拜的 ...
- XJOI 夏令营501-511NOIP训练18 高三楼
参观完各种饭堂,学校还有什么著名的景点呢?当然是教室了,此时此刻我 们来到了高三楼.你会发现高三楼门口会有以身份认证系统,这东西还有着一段疼人的历史.每年的九月到来,高三的童鞋大多不习惯学校的作息时间 ...
- Noip 训练指南
目录 Noip 训练指南 图论 数据结构 位运算 期望 题解 Noip 训练指南 目前完成 \(4 / 72\) 图论 [ ] 跳楼机 [ ] 墨墨的等式 [ ] 最优贸易 [ ] 泥泞的道路 [ ] ...
随机推荐
- Maven中解决jar包冲突的三种方式
首先我们在idea中创建一个maven工程,我们只关注pom.xml以及External Libraries中导入的jar包 导入spring-beans.jar <dependency> ...
- GCC 基础知识
目录 GCC 基础知识 一.GCC编译选项解析 二.多模块.多个文件一起编译 三.静态库与动态库 四.查看帮助文档 GCC 基础知识 一.GCC编译选项解析 1. 常用编译选项 命令格式:gcc [选 ...
- vs中web api程序不包含适合于入口点的静态“Main”方法
步骤:选择该项目的属性--应用程序--输出类型--类库
- Django模型层之单表操作
Django模型层之单表操作 一 .ORM简介 我们在使用Django框架开发web应用的过程中,不可避免地会涉及到数据的管理操作(如增.删.改.查),而一旦谈到数据的管理操作,就需要用到数据库管理软 ...
- Spring MVC前端控制器不拦截静态资源配置
- quartz2.3.0(四)JobDataMap—带状态集合的定时器内置集合
任务类 package org.quartz.examples.example4; import java.util.Date; import org.quartz.DisallowConcurren ...
- Java设计模式之委派模式(Dellegate/Dispather)
概述: 委派模式有点像代理模式又有点像策略模式. 区别在于代理模式注重过程,委派模式注重结果. 生活中也有很多委派模式的例子:例如公司老板给项目经理下达任务,将任务全权交给项目经理,有项目经理根据一定 ...
- CF1090H Linearization 构造、位运算、前缀和
传送门 有点神仙的题目 首先注意到对于串\(s\),\(b=s_0\)一定会比\(b = s_0 \bigoplus 1\)更优 考虑先分析linear串的性质.注意到位运算考虑按位处理.我们考虑\( ...
- application.yml报错:a global security auto-configuration is now provided
报错原因: Spring Boot 1.5升级到2.0改动 security开头的配置及management.security均已过期 Actuator 配置属性变化 Endpoint变化 参考来源: ...
- springboot笔记06——使用Thymeleaf模板引擎
前言 Springboot 推荐使用Thymeleaf做视图层.Thymeleaf支持 html 原型,然后在 html 标签里增加额外的属性来达到模板+数据的展示方式.浏览器解释 html 时会忽略 ...