2022USACO-DEC-Silver
题目链接
T1.Barn Tree
T2.Circular Barn
T3.Range Reconstruction
T1
下面均以\(1\)为根来进行分析。
算法思路:
首先,定义一个数组dis表示当前子树的干草数和与应有的干草数和的差值(多了为正,少了为负)。dis的求法就是裸的\(DFS\)。
接下来,进行\(DFS\)。
假设现在遍历到了以\(u\)为根的子树。
第一遍遍历\(u\)的所有孩子。如果当前孩子\(dis>=0\),则遍历以当前孩子为根的子树,并将该子树的所有多余干草全部干草上传到该孩子上,并将该孩子的干草上传到\(u\)上。
第二遍遍历\(u\)的所有孩子。如果当前孩子\(dis<0\),则遍历以当前孩子为根的子树,并将\(u\)的与\(-dis\)相等的干草全部干草下传到该孩子上,并在遍历以该孩子为根的子树。
代码实现
#include<bits/stdc++.h>
#pragma GCC optimize(2)
using namespace std;
typedef long long LL;
const int N = 2E5 + 5;
int n, u, v;
/*
up:pushup the things down:pushdown the things
*/
vector<LL> G[N], x, y, c;
LL h[N], ave, dis[N];
void newop(int from, int to, LL val) {
x.push_back(from);
y.push_back(to);
c.push_back(val);
}
void calc(int u, int f) {
dis[u] = h[u] - ave;
for (int v: G[u]) {
if (v == f) continue;
calc(v, u);
dis[u] += dis[v];
}
}
void dfs(int u, int f) {
for (int v: G[u]) {
if (v == f) continue;
if (dis[v] > 0) {
dfs(v, u);
newop(v, u, dis[v]);
}
if (dis[v] == 0) dfs(v, u);
}
for (int v: G[u]) {
if (v == f) continue;
if (dis[v] < 0) {
h[v] -= dis[v];
newop(u, v, -dis[v]);
dfs(v, u);
}
}
}
int main()
{
scanf("%d", &n);
for (int i = 1; i <= n; i++) scanf("%lld", h + i), ave += h[i];
ave /= n;
for (int i = 1; i < n; i++) {
scanf("%d %d", &u, &v);
G[u].push_back(v);
G[v].push_back(u);
}
calc(1, 0);
dfs(1, 0);
printf("%d\n", x.size());
for (int i = 0; i < x.size(); i++) printf("%lld %lld %lld\n", x[i], y[i], c[i]);
}
T2
算法思路
我们考虑如果一个人选择了\(4k\)型数,那么这个人必败。
归纳证明:
样例证明,\(4\)为必败态。
假设\(4, 8, \dots, 4k\)均为必败态。
那么\(4(k - 1)\)无法通过减去\(4m\)转移到另一个必败态,因为\(4m\)为合数。
证毕。
所以,\(4k\)必败。
那么对于\(4k+1\)型数,只需找到最大的\(4k+1\)型质数,减去即可,\(4k+3\)型数同理。
对于\(4k+2\)型数,只能转移到\(4k+2\)解决。
这个过程可以边做\(Eratosthenes\)筛,边用\(dp\)来解决。
代码实现
#include<bits/stdc++.h>
using namespace std;
const int N = 1E5 + 5, M = 5E6 + 5;
long long t, n, a[N], m, dp[M];
bool flag[M];
void init() {
int one = 0, three = 0;
for (int i = 2; i * i <= M - 5; i++) {
if (flag[i] == 0) for (int j = i * i; j <= M - 5; j += i) flag[j] = 1;
}
for (int i = 1; i <= M - 5; i++) {
if (!flag[i]) {
if (i % 4 == 1) one = i;
else if (i % 4 == 3) three = i;
}
if (i % 2 == 0) dp[i] = dp[i - 2] + 1;
else if (i % 4 == 1) dp[i] = dp[i - one] + 1;
else if (i % 4 == 3) dp[i] = dp[i - three] + 1;
}
}
int main()
{
init();
scanf("%lld", &t);
while(t--) {
scanf("%lld", &n);
for (int i = 1; i <= n; i++) scanf("%lld", &a[i]);
long long jj = LLONG_MAX, nn = LLONG_MAX;
for (long long i = 1; i <= n; i++) {
if (a[i] % 4 == 0) {
nn = min(nn, (dp[a[i]] / 2ll) * n + i);
}
else {
jj = min(jj, (dp[a[i]] / 2ll) * n + i);
}
}
if (jj < nn) printf("Farmer John\n");
else printf("Farmer Nhoj\n");
}
}
T3
算法思想
思想:暴力(是不是很惊讶?)
我们可以将\(a_1\)确定下来,直接赋值为\(0\)
我们考虑前\(i\)个都确定下来了,来确定第\(i + 1\)个。
第\(i + 1\)个只有两个选择:\(a_i - b_{i, i + 1}\)和\(a_i + b_{i, i + 1}\)。
依次用\(b_{j, i + 1}, j \in [1, i]\)判断即可。
代码实现
#include<bits/stdc++.h>
using namespace std;
const int N = 305;
int n;
long long Distance[N][N], construction[N];
bool Validator(int u) {
for(int i = 1; i < u; i++) {
long long maximum = -0x3F3F3F3F3F3F3F3F, minimum = 0x3F3F3F3F3F3F3F3F;
for (int j = i; j <= u; j++) {
maximum = max(maximum, construction[j]);
minimum = min(minimum, construction[j]);
}
if (maximum - minimum != Distance[i][u]) return false;
}
return true;
}
int main()
{
scanf("%d", &n);
for (int i = 1; i <= n; i++) {
for (int j = i; j <= n; j++) {
scanf("%lld", &Distance[i][j]);
}
}
construction[1] = 1;
for (int i = 2; i <= n; i++) {
construction[i] = construction[i - 1] + Distance[i - 1][i];
if (Validator(i)) continue;
construction[i] = construction[i - 1] - Distance[i - 1][i];
}
for (int i = 1; i <= n; i++) {
if (i != n) printf("%lld ", construction[i]);
else printf("%lld", construction[i]);
}
return 0;
}
2022USACO-DEC-Silver的更多相关文章
- USACO翻译:USACO 2013 DEC Silver三题
USACO 2013 DEC SILVER 一.题目概览 中文题目名称 挤奶调度 农场航线 贝西洗牌 英文题目名称 msched vacation shuffle 可执行文件名 msched vaca ...
- USACO翻译:USACO 2014 DEC Silver三题
USACO 2014 DEC SILVER 一.题目概览 中文题目名称 回程 马拉松 奶牛慢跑 英文题目名称 piggyback marathon cowjog 可执行文件名 piggyback ma ...
- Week Three
2018.12.10 1.[BZOJ 4818][P 3702] 2.[AGC007 A] 3.[AGC007 B] 4.[AGC007 C] 5.[AGC007 D] 2018.12.11 1.[B ...
- USACO Apple Delivery
洛谷 P3003 [USACO10DEC]苹果交货Apple Delivery 洛谷传送门 JDOJ 2717: USACO 2010 Dec Silver 1.Apple Delivery JDOJ ...
- USACO Building Roads
洛谷 P2872 [USACO07DEC]道路建设Building Roads 洛谷传送门 JDOJ 2546: USACO 2007 Dec Silver 2.Building Roads JDOJ ...
- USACO Milk Routing
洛谷 P3063 [USACO12DEC]牛奶的路由Milk Routing 洛谷传送门 JDOJ 2334: USACO 2012 Dec Silver 3.Milk Routing JDOJ传送门 ...
- LOJ10199轻拍牛头
题目描述 原题来自:USACO 2008 Dec. Silver 今天是 Bessie 的生日,并且现在是聚会的游戏时间.Bessie 让编号为 1~N 的 N 头奶牛围成一个圈坐(所以除了最后一头牛 ...
- [USACO] 2017 DEC Bronze&Silver
link:http://www.usaco.org/index.php?page=dec17results Problem A(Bronze) 这是一道非常简单的判断重叠面积的题目,但第一次提交仍会出 ...
- Bzoj 3389: [Usaco2004 Dec]Cleaning Shifts安排值班 最短路,神题
3389: [Usaco2004 Dec]Cleaning Shifts安排值班 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 218 Solved: ...
- Bzoj 1648: [Usaco2006 Dec]Cow Picnic 奶牛野餐 深搜,bitset
1648: [Usaco2006 Dec]Cow Picnic 奶牛野餐 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 554 Solved: 346[ ...
随机推荐
- Dropout----Dropout来源
目录 一.简单介绍及公式 二.为什么dropout有效-原因定性分析 2.1 ensemble论 2.1.1 ensemble 2.1.2 动机:联合适应(co-adapting) 思考: 2.1.3 ...
- Vue学习之--------深入理解Vuex之模块化编码(2022/9/4)
在以下文章的基础上 1.深入理解Vuex.原理详解.实战应用:https://blog.csdn.net/weixin_43304253/article/details/126651368 2.深入理 ...
- LeetCode------递归(爬楼梯)
1.递归 1.一个问题的解可以分解为几个子问题的解. 2.这个问题与分解之后的子问题,除了数据规模不同,求解思路完全一样 3.存在基线/终止条件 来源:力扣(LeetCode) 链接:https:// ...
- 变量的复制&传递
变量的复制 变量的类型 可以分为基本数据类型(Null.Undefined.Number.String.Boolean)和引用类型(Funtion.Object.Array) 基本数据类型是按照值访问 ...
- CF815D
模拟赛遇到的题目. 看各位大佬的做法都不是很懂,于是自己一通乱搞搞出来了. 题意 翻译清楚的不能再清楚了 做法 为了方便叙述,我们将每个给出的三元组表示成 \((a_i,b_i,c_i)\),所选的三 ...
- 死磕Java面试系列:深拷贝与浅拷贝的实现原理
深拷贝与浅拷贝的问题,也是面试中的常客.虽然大家都知道两者表现形式不同点在哪里,但是很少去深究其底层原理,也不知道怎么才能优雅的实现一个深拷贝.其实工作中也常常需要实现深拷贝,今天一灯就带大家一块深入 ...
- JUC学习笔记——共享模型之管程
JUC学习笔记--共享模型之管程 在本系列内容中我们会对JUC做一个系统的学习,本片将会介绍JUC的管程部分 我们会分为以下几部分进行介绍: 共享问题 共享问题解决方案 线程安全分析 Monitor ...
- DTSE Tech Talk | 第10期:云会议带你入门音视频世界
摘要:本期直播主题是<云会议带你入门音视频世界>,华为云媒体服务产品部资深专家金云飞,与开发者们交流华为云会议在实时音视频行业中的集成应用,帮助开发者更好的理解华为云会议及其开放能力. 本 ...
- zephyr的GPIOTE驱动开发记录——基于nordic的NCS
简介: 本次测试了zephyr的中断驱动方式(GPIOTE),在这可以去看zephyr的官方文档对zephyr的中断定义,连接如下,Interrupts - Zephyr Project Docume ...
- WIN10使用SSH连接VMWare16 Pro的CentOS8.4(保姆级)
目录 本机环境 配置连接 本机环境 连接工具用的是MobaXterm,下载地址https://mobaxterm.mobatek.net/download.html VMWare16 Pro Cent ...