夏令营提高班上午上机测试 Day 2 解题报告
题目描述小G有一群好朋友,他们经常互相借钱。假如说有三个好朋友A,B,C。A欠B20元,B欠C20元,总债务规模为20+20=40元。小G是个追求简约的人,他觉得这样的债务太繁杂了。他认为,上面的债务可以完全等价为A欠C20元,B既不欠别人,别人也不欠他。这样总债务规模就压缩到了 20 元。现在给定n个人和m条债务关系。小G想找到一种新的债务方案,使得每个人欠钱的总数不变,或被欠钱的总数不变(但是对象可以发生变化),并且使得总债务规模最小。输入格式输入文件第一行两个数字 n, m,含义如题目所述。接下来 m 行,每行三个数字 ai, bi, ci ,表示 ai欠 bi的钱数为 ci。注意,数据中关于某两个人 A 和 B 的债务信息可能出现多次,将其累加即可。如”A 欠 B 20 元”、”A 欠 B 30 元”、”B 欠 A 10 元”,其等价为”A 欠 B 40 元”。输出格式输出文件共一行,输出最小的总债务规模。样例输入 15 31 2 102 3 12 4 1样例输出 110样例输入 24 31 2 12 3 13 1 1样例输出 20数据范围对于 30% 的数据,1 ≤ n ≤ 10,1 ≤ m ≤ 10。对于 60% 的数据,1 ≤ n ≤ 100, 1 ≤ m ≤ 104。对于 80% 的数据,1 ≤ n ≤ 104,1 ≤ m ≤ 104。对于 100% 的数据,1 ≤ n ≤ 106,1 ≤ m ≤ 106。对于所有的数据,保证 1 ≤ ai, bi≤ n, 0 < ci≤ 100。
#include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib>
#include <iostream>
using namespace std; const int max_n = 1e6 + ;
const int max_m = 1e6 + ;
int a[max_n]; inline int getnum()
{
int ans = ; bool flag = false;
char c;
while ((c = getchar()) == ' ' || c == '\n' || c == '\r');
if (c == '-') flag = true;
else ans = c - '';
while (isdigit(c = getchar()))
ans = ans * + c - '';
return ans;
} int main()
{
freopen("debt.in", "r", stdin);
freopen("debt.out", "w", stdout);
int n = getnum();
int m = getnum();
for (int i = ; i <= m; i++)
{
int aa, bb, c;
aa = getnum(); bb = getnum(); c = getnum();
a[aa] += c; a[bb] -= c;
}
int ans = ;
for (int i = ; i <= n; i++)
if (a[i] > ) ans += a[i];
cout << ans << endl;
}
题目描述小 G 喜欢玩排列。现在他手头有两个 n 的排列。n 的排列是由 0, 1, 2, ..., n − 1这 n 的数字组成的。对于一个排列 p,Order(p) 表示 p 是字典序第 Order(p) 小的排列(从 0 开始计数)。对于小于 n! 的非负数 x,Perm(x) 表示字典序第 x 小的排列。现在,小 G 想求一下他手头两个排列的和。两个排列 p 和 q 的和为 sum = Perm((Order(p) + Order(q))%n!)。输入格式输入文件第一行一个数字 n,含义如题。接下来两行,每行 n 个用空格隔开的数字,表示小 G 手头的两个排列。输出格式输出一行 n 个数字,用空格隔开,表示两个排列的和。样例输入 120 11 0样例输出 11 0样例输入 231 2 02 1 0样例输出 21 0 2数据范围1、2、3、4 测试点,1 ≤ n ≤ 10。5、6、7 测试点,1 ≤ n ≤ 5000,保证第二个排列的 Order ≤ 105。8、9、10 测试点,1 ≤ n ≤ 5000。
#include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib>
#include <iostream>
#include <algorithm>
using namespace std; const int max_n = 5e4 + ;
int cnt[max_n], p1[max_n], p2[max_n], pp1[max_n], pp2[max_n], ans[max_n];
int n; inline int getnum()
{
int ans = ; char c; bool flag = false;
while ((c = getchar()) == ' ' || c == '\n' || c == '\r');
if (c == '-') flag = true; else ans = c - '';
while (isdigit(c = getchar())) ans = ans * + c - '';
return ans * (flag ? - : );
} int main()
{
freopen("perm.in", "r", stdin);
freopen("perm.out", "w", stdout);
n = getnum();
for (int i = n; i >= ; i--) p1[i] = getnum();
for (int i = n; i >= ; i--) p2[i] = getnum(); for (int i = ; i <= n; i++)
for (int j = ; j < i; j++)
if (p1[j] < p1[i]) pp1[i]++;
for (int i = ; i <= n; i++)
for (int j = ; j < i; j++)
if (p2[j] < p2[i]) pp2[i]++; for (int i = ; i <= n; i++)
{
ans[i] += pp1[i] + pp2[i];
ans[i + ] += ans[i] / i;
ans[i] %= i;
} for (int i = n; i >= ; i--)
{
int _ = -;
while (ans[i] >= )
{
_++;
if (!cnt[_]) ans[i]--;
}
printf("%d ", _);
cnt[_] = ;
}
}
题目描述rzyz 有一棵苹果树。苹果树有 n 个节点(也就是苹果),n − 1 条边(也就是树枝)。调皮的小 G 爬到苹果树上。他发现这棵苹果树上的苹果有两种:一种是黑苹果,一种是红苹果。小 G 想要剪掉 k 条树枝,将整棵树分成 k + 1 个部分。他想要保证每个部分里面有且仅有一个黑苹果。请问他一共有多少种剪树枝的方案?输入格式第一行一个数字 n,表示苹果树的节点(苹果)个数。第二行一共 n − 1 个数字 p0, p1, p2, p3, ..., pn-2,pi 表示第 i + 1 个节点和 pi节点之间有一条边。注意,点的编号是 0 到 n − 1。第三行一共 n 个数字 x0, x1 , x2 , x3 , ..., xn-1 。如果 x 是 1,表示 i 号节点是黑苹果;如果 x 是 0,表示 i 号节点是红苹果。输出格式输出一个数字,表示总方案数。答案对 109+ 7 取模。样例输入 130 00 1 1样例输出 12样例输入 260 1 1 0 41 1 0 0 1 0样例输出 21样例输入 3100 1 2 1 4 4 4 0 80 0 0 1 0 1 1 0 0 1样例输出 327数据范围对于 30% 的数据,1 ≤ n ≤ 10。对于 60% 的数据,1 ≤ n ≤ 100。对于 80% 的数据,1 ≤ n ≤ 1000。对于 100% 的数据,1 ≤ n ≤ 105。对于所有数据点,都有 0 ≤ pi≤ n − 1,xi = 0 或 xi = 1。特别地,60% 中、80% 中、100% 中各有一个点,树的形态是一条链。
- i点是黑色的,所有i的子树v和i相接,必须接dp[v][0]。
- i点是红色的,所有i的子树,有一棵接dp[v][1],其余的接dp[v][0]。
- i点是黑色的,所有i的子树v和i相接,必须接dp[v][0],并且i上面的那条边得割断。
- i点是红色的,所有i的子树,有一棵接dp[v][1],其余的接dp[v][0],且i上面的那条边得割断。
- i点是红色的,所有i的子树v和i相接,都接dp[v][0]。
- 子树全都用dp[v][0]。
- 子树一棵用dp[v][1],其余用dp[v][0]。
#include <cstdio>
#include <cmath>
#include <cstring>
#include <cstdlib>
#include <iostream>
using namespace std; #define ll long long
const int MAXN = 1e5 + ;
const int MOD = 1e9 + ; ll f[MAXN][];
int point[MAXN] = {}, nxt[MAXN * ] = {}, v[MAXN * ] = {}, tot = ;
bool color[MAXN] = {};
int n; inline void addedge(int x, int y)
{
tot++;
nxt[tot] = point[x]; point[x] = tot; v[tot] = y;
} void dfs(int now, int father)
{
f[now][] = ;
f[now][] = ;
for (int tmp = point[now]; tmp; tmp = nxt[tmp])
if (v[tmp] != father)
{
dfs(v[tmp], now);
f[now][] = (f[now][] * f[v[tmp]][]) % MOD;
f[now][] = (f[now][] + f[now][] * f[v[tmp]][]) % MOD;
f[now][] = (f[now][] * f[v[tmp]][]) % MOD;
}
if (color[now])
f[now][] = f[now][];
else
f[now][] = (f[now][] + f[now][]) % MOD;
} int main()
{
freopen("tree.in", "r", stdin);
freopen("tree.out", "w", stdout);
scanf("%d", &n);
for (int i = ; i <= n; i++)
{
int x;
scanf("%d", &x);
addedge(i, x + ); addedge(x + , i);
}
for (int i = ; i <= n; i++)
{
int x;
scanf("%d", &x);
if (x == ) color[i] = true;
else color[i] = false;
}
dfs(, );
cout << f[][] << endl;
}
夏令营提高班上午上机测试 Day 2 解题报告的更多相关文章
- 夏令营提高班上午上机测试 Day 3 解题报告
今天的题的确水.T3还是一道NOIP原题. 嘛,多刷点水题也不是什么坏事嘛. 说来也快,夏令营结束了整一星期了呢.大家也都回到了日常的暑假生活呢. 今天学业水平测试出成绩了...嗯结果还算满意呢,至少 ...
- 夏令营提高班上午上机测试 Day 4 解题报告
我要是没记错的话,今天的题难度算挺适中的. *标程来自高天宇哥哥 T1:小G的字符串 题目描述 有一天,小 L 给小 G 出了这样一道题:生成一个长度为 n 的.全由小写英文字母构成的字符串,只能使用 ...
- 夏令营提高班上午上机测试 Day 1 解题报告
Day 1的题难度上来说不算太高,但是T2和T3还是有一定的思维量的. 一个比较好的开始.虽然AK的人只有几个.. (懒得去翻result了..忘了当时拿了多少分了 (哦,前两天我们机房是没有成绩的, ...
- nowcoder(牛客网)OI测试赛3 解题报告
昨天因为胡搞了一会儿社团的事情,所以错过(逃过)了nowcoder的测试赛..... 以上,听说还是普及组难度qwq,而且还有很多大佬AK(然而我这么蒻肯定还是觉得有点难度的吧qwq) 不过我还是日常 ...
- 牛客OI赛制测试赛3 解题报告
前话: 话说考试描述:普及难度. 于是想在这场比赛上涨点信心. 考出来的结果:Point:480 Rank:40 然而同机房的最好成绩是 510. 没考好啊!有点炸心态,D题一些细节没有注意, ...
- nowcoder(牛客网)提高组模拟赛第四场 解题报告
T1 动态点分治 就是模拟..... 但是没有过!! 看了题解之后发现.... 坑点:有可能 \(x<=r\),但是
- nowcoder(牛客网)OI测试赛2 解题报告
qwq听说是一场普及组难度的比赛,所以我就兴高采烈地过来了qwq 然后发现题目确实不难qwq.....但是因为蒟蒻我太蒻了,考的还是很差啦qwq orz那些AK的dalao们qwq 赛后闲来无事,弄一 ...
- nowcoder 提高组模拟赛 最长路 解题报告
最长路 链接: https://www.nowcoder.com/acm/contest/178/A 来源:牛客网 题目描述 有一张 \(n\) 个点 \(m\) 条边的有向图,每条边上都带有一个字符 ...
- [jzoj 4668] [NOIP2016提高A组模拟7.19] 腐败 解题报告(质数分类+慢速乘)
题目链接: http://172.16.0.132/senior/#main/show/4668 题目: 题解: 考虑把A数组里的每个元素分解质因数,对于每个质因数开一个vector存一下包含这个质因 ...
随机推荐
- HDU Today(最短路)
http://acm.hdu.edu.cn/showproblem.php?pid=2112 HDU Today Time Limit: 15000/5000 MS (Java/Others) ...
- flume1.8 基础架构介绍(一)
1. 系统要求 1. Java运行环境 -- Java 1.8及以上 2. 内存 -- 足够的内存供配置的sources,channels 或者sinks使用 3. 硬盘空间 -- 足够的硬盘空间供配 ...
- LinkedHashMap 源码详细分析(JDK1.8)
1. 概述 LinkedHashMap 继承自 HashMap,在 HashMap 基础上,通过维护一条双向链表,解决了 HashMap 不能随时保持遍历顺序和插入顺序一致的问题.除此之外,Linke ...
- [国嵌笔记][011][Linux密码破解]
破解步骤 1.在系统启动时进入grub选项菜单 2.在grub选项菜单中按e进入编辑模式 3.编辑kernel行,添加 /init 1 (表示进入单用户启动模式,在单用户启动模式中不会要求输入密码) ...
- Python3 的函数
1.编写power(x,y)函数返回x的y次幂值 def power(x,y): return x**y 2.求最大公约数 def gcd(x,y): r=x%y x=y y=r if r==0: p ...
- [拾 得] zip gzip bzip2 & tar 压缩/打包 四大金刚
坚持知识分享,该文章由Alopex编著, 转载请注明源地址: http://www.cnblogs.com/alopex/ 索引: 介绍压缩和打包 gzip bzip2 zip 的基本使用 gz ...
- Java中 equals() 和 == 的区别
1)对于==,如果作用于基本数据类型的变量,则直接比较其存储的 "值"是否相等: 如果作用于引用类型的变量,则比较的是所指向的对象的地址 2)对于equals方法,注意:equal ...
- 顺序一致性内存模型与JMM的“顺序一致性”
顺序一致性内存模型是一个被计算机科学家理想化了的理论参考模型,它为程序员提供了极强的内存可见性保证.顺序一致性内存模型有两大特性.1)一个线程中的所有操作必须按照程序的顺序来执行.2)(不管程序是否同 ...
- mysql 查看索引使用情况
show status like 'Handler_read%'; Handler_read_key 代表着一个行被索引值读取的次数,值很低表明索引不经常用到,增加索引对性能改善不高. Handle ...
- mysq开启慢查询
1 将未建立索引的sql放到慢查询日志中 查看 log_queries_not_using_indexes 是否为on show variables like 'log%'; 将 log_querie ...