Replay


Dup4:

  • 两轮怎么退火啊?
  • 简单树形dp都不会了,送了那么多罚时
  • 简单题都不想清楚就乱写了,喵喵喵?

X:

  • 欧拉怎么回路啊, 不会啊。
  • 还是有没有手误?未思考清楚或者未检查就提交, 导致自己白送罚时。

A:夺宝奇兵

Solved.

考虑$所有i >= 2 需要跟i - 1 连两条边 只有两种可能 取最小的一种$

$注意n的两个点要连一条边$

 #include<bits/stdc++.h>

 using namespace std;

 typedef long long ll;

 const int maxn = 1e5 + ;

 struct node{
int x1, x2, y1, y2;
}arr[maxn]; ll calc(int i,int j)
{
ll ans1 = abs(arr[i].x1 - arr[j].x1) + abs(arr[i].y1 - arr[j].y1) + abs(arr[i].x2 - arr[j].x2) + abs(arr[i].y2 - arr[j].y2);
ll ans2 = abs(arr[i].x1 - arr[j].x2) + abs(arr[i].y1 - arr[j].y2) + abs(arr[i].x2 - arr[j].x1) + abs(arr[i].y2 - arr[j].y1);
return min(ans1, ans2);
} int n , m; int main()
{
while(~scanf("%d %d", &n, &m))
{
for(int i = ; i <= n; ++i) scanf("%d %d %d %d", &arr[i].x1, &arr[i].y1, &arr[i].x2, &arr[i].y2);
ll ans = ;
for(int i = ; i <= n; ++i) ans += calc(i, i - );
ans += abs(arr[n].x1 - arr[n].x2) + abs(arr[n].y1 - arr[n].y2);
printf("%lld\n", ans);
}
return ;
}

C:最小边覆盖

Solved.

考虑$No的情况$

  • 存在一个点的度数为0(没有被覆盖)
  • 存在一条边所连接的两个点其度数 >= 2 即这条边去掉还是个最小边覆盖
 #include <bits/stdc++.h>
using namespace std; #define N 300010
#define pii pair <int, int>
int n, m;
pii G[N];
int d[N]; bool f()
{
for (int i = ; i <= n; ++i) if (!d[i]) return false;
for (int i = ; i <= m; ++i)
{
int u = G[i].first, v = G[i].second;
if (d[u] >= && d[v] >= )
return false;
}
return true;
} int main()
{
while (scanf("%d%d", &n, &m) != EOF)
{
memset(d, , sizeof d);
for (int i = , u, v; i <= m; ++i)
{
scanf("%d%d", &u, &v);
++d[u], ++d[v];
G[i] = pii(u, v);
}
puts(f() ? "Yes" : "No");
}
return ;
}

F:小小马

Solved.

因为不同颜色出现次数相同, 所以步数一定是奇数。

暴力跑出大数据的状态, 发现颜色相同就输出No, 否则输出Yes。

小数据暴力跑即可

 #include<bits/stdc++.h>

 using namespace std;

 const int maxn = 1e6 + ;

 struct node{
int x, y;
int step;
node(){}
node(int x, int y, int step): x(x), y(y), step(step){}
}; int n, m;
int sx, sy, ex, ey;
int vis[][maxn][];
int dir[][] = {-, -, -, , -, -, -, , , -, , , , -, , }; int judge(int x, int y,int step)
{
if(x < || x > n || y < || y > m || vis[x][y][step % ]) return false;
else return true;
} void BFS()
{
memset(vis, , sizeof vis);
queue<node>q;
q.push(node(sx, sy, ));
while(!q.empty())
{
node st = q.front();
q.pop();
node now = st;
now.step++;
for(int i = ; i < ; ++i)
{
now.x = st.x + dir[i][];
now.y = st.y + dir[i][];
if(judge(now.x, now.y, now.step))
{
vis[now.x][now.y][now.step % ] = ;
q.push(now);
}
}
}
} int main()
{
while(~scanf("%d %d", &n, &m))
{
scanf("%d %d", &sx, &sy);
scanf("%d %d", &ex, &ey);
if(n < || m < )
{
if(n > m)
{
swap(n, m);
swap(sx, sy);
swap(ex, ey);
}
BFS();
if(vis[ex][ey][]) puts("Yes");
else puts("No");
}
else
{
int ans1 = (sx + sy) % ;
int ans2 = (ex + ey) % ;
if(ans1 != ans2) puts("Yes");
else puts("No");
}
}
return ;
}

G:置置置换

Solved.

$在已知1-n的方案数, 枚举n+1出现的位置$

$当枚举到位置x的时候, 选出x-1个数放在前x个, 然后计算方案数 统计即可$

$2 \cdot ans_{n + 1} = \sum\limits_{i = 0}^{n} C_n^i \cdot ans_i \cdot ans_{n - i}$

 #include <bits/stdc++.h>

 using namespace std;

 typedef long long ll;

 const ll MOD = (ll)1e9 + ;
const int maxn = 1e3 + ; int n;
ll fac[maxn];
ll inv[maxn];
ll invfac[maxn]; ll ans[maxn]; void Init()
{
fac[] = , inv[] = , invfac[] = ;
for(int i = ; i < maxn; ++i)
{
fac[i] = fac[i - ] * i % MOD;
inv[i] = inv[MOD % i] * (MOD - MOD / i) % MOD;
invfac[i] = invfac[i - ] * inv[i] % MOD;
}
} ll calc(int n, int m)
{
if(n == m || m == ) return 1ll;
return fac[n] * invfac[m] % MOD * invfac[n - m] % MOD;
} int main()
{
Init();
ans[] = ans[] = ;
for(int i = ; i + < maxn; ++i)
{
for(int j = ; j <= i; ++j)
{
ans[i + ] = (ans[i + ] + calc(i, j) * ans[j] % MOD * ans[i - j] % MOD) % MOD;
}
ans[i + ] = (ans[i + ] * inv[]) % MOD;
}
while (scanf("%d", &n) != EOF)
{
printf("%lld\n", ans[n]);
}
return ;
}

I:咆咆咆哮

Solved.

考虑如果选择$a_i的个数固定为x,那么对于所有选取b_i的卡牌来说它的贡献是固定的$

枚举$x, 再贪心选取即可$

 #include <bits/stdc++.h>
using namespace std; #define ll long long
#define N 1010
int n, a[N], b[N]; ll f(int x)
{
priority_queue <ll> pq;
ll res = ;
for (int i = ; i <= n; ++i)
{
res += a[i];
pq.push(1ll * b[i] * x - a[i]);
}
for (int i = ; i <= n - x; ++i)
{
res += pq.top();
pq.pop();
}
return res;
} int main()
{
while (scanf("%d", &n) != EOF)
{
for (int i = ; i <= n; ++i) scanf("%d%d", a + i, b + i);
ll res = ;
for (int i = ; i <= n; ++i)
res = max(res, f(i));
printf("%lld\n", res);
}
return ;
}

Div1:

三分

好像满足凸性? 我不会证啊。..

 #include <bits/stdc++.h>
using namespace std; #define ll long long
#define N 100010
int n, a[N], b[N]; ll check(int x)
{
ll res = ;
priority_queue <ll> pq;
for (int i = ; i <= n; ++i)
{
res = res + a[i];
pq.push(1ll * b[i] * x - a[i]);
}
for (int i = n - x; !pq.empty() && i; --i)
{
res += pq.top(); pq.pop();
}
return res;
} int main()
{
while (scanf("%d", &n) != EOF)
{
for (int i = ; i <= n; ++i) scanf("%d%d", a + i, b + i);
int l = , r = n; ll res = ;
while (r - l >= )
{
int midl = (l + r) >> ;
int midr = (midl + r) >> ;
ll tmpl = check(midl);
ll tmpr = check(midr);
if (tmpl <= tmpr)
{
res = max(res, tmpr);
l = midl + ;
}
else
{
res = max(res, tmpl);
r = midr - ;
}
}
printf("%lld\n", res);
}
return ;
}

K:两条路径

Solved.

考虑$x作为交它的权值要被算上$

在考虑两条路径可以选取端点,端点的选择在其儿子对应的子树中选取一个点且仅能选取一个

树形DP即可

 #include <bits/stdc++.h>
using namespace std; #define ll long long
#define N 100010
#define INFLL 0x3f3f3f3f3f3f3f3f
int n, q;
ll val[N];
vector <int> G[N];
ll Bit[], f[N]; void DFS(int u, int fa)
{
f[u] = -INFLL;
for (auto v : G[u]) if (v != fa)
{
DFS(v, u);
f[u] = max(f[u], f[v]);
}
f[u] = max(f[u], 0ll);
f[u] += val[u];
} void out(ll x)
{
if (x < ) putchar('-'), x = -x;
string res = "";
while (x)
{
res += (x % + '');
x /= ;
}
reverse(res.begin(), res.end());
cout << res << "\n";
} int main()
{
Bit[] = ;
for (int i = ; i <= ; ++i) Bit[i] = Bit[i - ] << ;
while (scanf("%d", &n) != EOF)
{
for (int i = ; i <= n; ++i) G[i].clear();
for (int i = , x; i <= n; ++i)
{
scanf("%d", &x);
if (!x)
{
val[i] = ;
continue;
}
int vis = ;
if (x < )
{
x = -x;
vis = -;
}
--x;
val[i] = Bit[x] * vis;
}
for (int i = , u, v; i < n; ++i)
{
scanf("%d%d", &u, &v);
G[u].push_back(v);
G[v].push_back(u);
}
int x;
scanf("%d", &q);
while (q--)
{
scanf("%d", &x);
priority_queue <ll> pq;
for (auto v : G[x])
{
DFS(v, x);
pq.push(f[v]);
}
ll res = val[x];
for (int i = ; i <= && !pq.empty() && pq.top() > ; ++i)
{
res += pq.top(); pq.pop();
}
//cout << res << endl;
out(res);
}
}
return ;
}

CCPC-Wannafly Winter Camp Day4 (Div2, onsite)的更多相关文章

  1. 2019 CCPC-Wannafly Winter Camp Day4(Div2, onsite)

    slove 6/11 A.夺宝奇兵 Code:zz Thinking:zz 贪心即可.这条路线里,点n1和点n2肯定是相连的,接下来,点(n-1)1和点(n-1)2分别是和n1和点n2相连的,一共有两 ...

  2. 2020 CCPC Wannafly Winter Camp Day1 C. 染色图

    2020 CCPC Wannafly Winter Camp Day1 C. 染色图 定义一张无向图 G=⟨V,E⟩ 是 k 可染色的当且仅当存在函数 f:V↦{1,2,⋯,k} 满足对于 G 中的任 ...

  3. CCPC Wannafly Winter Camp Div2 部分题解

    Day 1, Div 2, Prob. B - 吃豆豆 题目大意 wls有一个\(n\)行\(m\)列的棋盘,对于第\(i\)行第\(j\)列的格子,每过\(T[i][j]\)秒会在上面出现一个糖果, ...

  4. CCPC-Wannafly Winter Camp Day5 (Div2, onsite) Sorting(线段树)

    题目链接 题意 对序列进行三种操作: 1.区间求和. 2.将区间小于等于$x$的数不改变相对顺序的前提下放到$x$左边,用同样规则将比$x$大的放到右边. 3.将区间大于$x$的数不改变相对顺序的前提 ...

  5. CCPC-Wannafly Winter Camp Day8 (Div2, onsite)

    咕咕咕.    camp补题. 传送门:https://www.zhixincode.com/contest/29/problems A.Aqours 题意:有一棵有根树,根节点为1,给出每个结点的父 ...

  6. CCPC-Wannafly Winter Camp Day3 (Div2, onsite)

    Replay Dup4: 没想清楚就动手写? 写了两百行发现没用?想的还是不够仔细啊. 要有莽一莽的精神 X: 感觉今天没啥输出啊, 就推了个公式?抄了个板子, 然后就一直自闭A. 语文差,题目没理解 ...

  7. 2019 CCPC-Wannafly Winter Camp Day1 (Div2, onsite)

    solve:4/11 补题:6/11 A 机器人 补题:zz 这是一道分类讨论的题目,有一个规律就是如果必须要从第一个区到第二个区,那么最多转区两次(1到2一次,2到1一次),然后分类讨论即可,只要细 ...

  8. 2019 CCPC-Wannafly Winter Camp Day7(Div2, onsite)

    solve 6/11 补题: A.迷宫 Code:zz Thinking:zz kk 把每个节点的深度都处理出来,同一深度的点的冲突度为 (x-1),x为同层次点数减一. 然后冲突度不断下传(冲突度为 ...

  9. Wannafly Winter Camp Day8(Div1,onsite) E题 Souls-like Game 线段树 矩阵乘法

    目录 Catalog Solution: (有任何问题欢迎留言或私聊 && 欢迎交流讨论哦 Catalog @ Problem:传送门  Portal  原题目描述在最下面.  简单的 ...

随机推荐

  1. 用gcc编译成可执行程序 (转)

    #gcc hello.c 该命令将hello.c直接生成最终二进制可执行程序a.out 这条命令隐含执行了(1)预处理.(2)汇编.(3)编译并(4)链接形成最终的二进制可执行程序.这里未指定输出文件 ...

  2. 十分钟理解Java中的动态代理

    十分钟理解 Java 中的动态代理   一.概述 1. 什么是代理 我们大家都知道微商代理,简单地说就是代替厂家卖商品,厂家“委托”代理为其销售商品.关于微商代理,首先我们从他们那里买东西时通常不知道 ...

  3. MYSQL系列之(一)

      mysql简介 1.什么是数据库 ? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,它产生于距今六十多年前,随着信息技术和市场的发展,特别是二十世纪九十年代以后,数据管理不 ...

  4. Python 如何引入自定义模块

    Python 中如何引用自己创建的源文件(*.py)呢? 也就是所谓的模块. 假如,你有一个自定义的源文件,文件名:saySomething.py .里面有个函数,函数名:sayHello.如下图: ...

  5. DNS、链接网页、资源预加载处理

    从网页性能的角度来看,DNS的解析时间是比较耗时的.因此如果能预先下载网页中用到的其它域的资源.可提前进行DNS解析: <link rel="dns-prefetch" hr ...

  6. 禁止同一条ajax请求重复发出的方法

    在项目中,遇到的问题是: 四个tab发送四个不同的请求,当用户连续在不同的按钮之间来回切换时,会出现不清楚那条数据是需要展示的的问题,和当连续点击同一个按钮时,基本同时返回的数据会全都展示出来的问题. ...

  7. C# 验证码生成

    后台: //生成验证码 public void CreateImage() { //获取4位验证码,并转成小写. ).ToLower(); //验证码赋值Cookie HttpCookie myCoo ...

  8. 关于word文档转成html网页的方法

    在工作中,有时我们可能需要将一个word文档转换成html网页格式,如在写帮助文档的时候,采用office编写,最终却想以网页的格式传到网站的指定目录下供网友直接浏览 这时我们就需要对word文件进行 ...

  9. ios Quartz 各种绘制图形用法

    摘要: CoreGraphics的功能非常强大,可以绘制各种图形:今天学习一下怎么绘制简单的点线面,记录学习. 一.导入coreGraphics.framework 二.绘制图形 1.绘制矩形 // ...

  10. 在ScrollView嵌套GridView,使GridView不滚动

    <ScrollView>       ……   <LinearLayout> </LinearLayout>       ……</ScrollView> ...