AtCoder Regular Contest 090 C D E F
C - Candies
题意
求左上角走到右下角最大的数字和。
思路
直接\(dp\)
Code
#include <bits/stdc++.h>
#define maxn 110
using namespace std;
int a[3][maxn], dp[3][maxn];
typedef long long LL;
int main() {
int n;
scanf("%d", &n);
for (int i = 1; i <= 2; ++i) {
for (int j = 1; j <= n; ++j) scanf("%d", &a[i][j]);
}
for (int i = 1; i <= n; ++i) dp[1][i] = dp[1][i-1] + a[1][i];
for (int i = 1; i <= 2; ++i) dp[i][1] = dp[i-1][1] + a[i][1];
for (int j = 2; j <= n; ++j) {
dp[2][j] = max(dp[1][j], dp[2][j-1]) + a[2][j];
}
printf("%d\n", dp[2][n]);
return 0;
}
D - People on a Line
题意
给定 \(n\) 个未知数 \(x_1,...x_n\) 与 \(m\) 个等式 \(x_{p_i}-x_{q_i}=d_i\),问是否可能成立?(即是否存在矛盾)
思路
神似 poj 2492 A Bug's Life 二分图染色 || 种类并查集
对于并查集中的元素,用 \(off[\ ]\) 数组记录它比它的祖先大多少,合并的时候注意一下。
有条件$$l-fl=off[l]\ &&\ r-fr=off[r]\ &&\ r-l=d$$
于是有
\]
Code
#include <bits/stdc++.h>
#define maxn 100000
using namespace std;
typedef long long LL;
int fa[maxn], off[maxn];
int find(int x) {
if (fa[x] == x) return x;
int temp = fa[x];
fa[x] = find(fa[x]);
off[x] += off[temp];
return fa[x];
}
int main() {
int n, m;
scanf("%d%d", &n, &m);
for (int i = 1; i <= n; ++i) fa[i] = i;
for (int i = 0; i < m; ++i) {
int l, r, d;
scanf("%d%d%d", &l, &r, &d);
int fl = find(l), fr = find(r);
if (fl == fr) {
if (off[r] - off[l] == d) continue;
else { puts("No"); return 0; }
}
else {
fa[fr] = fl;
off[fr] = d - off[r] + off[l];
}
}
puts("Yes");
return 0;
}
E - Avoiding Collision
题意
给定一张图,甲乙两人分别从 \(s\) , \(t\) 出发,甲要到 \(t\),乙要到 \(s\),且两人均走最短路。
问在途中不相遇的方案数。
思路
跑两遍 \(dijkstra\),跑的时候记录最短路长度\(dist[\ ]\)和方案数\(way[\ ]\)。
显然,两人不能走同样的路,所以如果没有 在途中不相遇 的条件约束,则答案为 $$ans = ways1[t]*(ways1[t]-1])$$
然而,题目要求 在途中不相遇,这蕴含了两层含义,在 点 上不相遇,在 边 上不相遇。
// 千万别忘了边Orz
在 点 上不相遇:
枚举点,判断是否 $$dist1[i]2==dis\ &&\ dist2[i]2==dis$$
在 边 上不相遇:
枚举边,判断是否 $$dist1[u] + edge[id].w + dist2[v] == dis\ &&\ (dist1[u]<<1) < dis\ &&\ (dist2[v]<<1) < dis$$
用总答案减去这两部分 \(ans - ans1 - ans2\) 即为答案
Code
#include <bits/stdc++.h>
#define maxn 100010
#define maxm 200010
#define inf 0x3f3f3f3f3f3f3f3f
using namespace std;
typedef long long LL;
const LL mod = 1e9 + 7;
int ne[maxn], tot;
bool vis[maxn];
LL dist1[maxn], dist2[maxn], ways1[maxn], ways2[maxn];
struct Edge { int from, to, ne; LL w; }edge[maxm<<1];
void add(int u, int v, LL w) {
edge[tot] = {u, v, ne[u], w};
ne[u] = tot++;
}
struct node {
int v; LL c;
bool operator < (const node nd) const { return c > nd.c; }
};
int n;
void dfs(int src, LL* dist, LL* ways) {
memset(vis, 0, sizeof vis);
for (int i = 1; i <= n; ++i) dist[i] = inf;
vis[src] = true; dist[src] = 0; ways[src] = 1;
priority_queue<node> q;
while (!q.empty()) q.pop();
while (true) {
for (int j = ne[src]; ~j; j = edge[j].ne) {
int v = edge[j].to;
if (vis[v]) continue;
LL now = edge[j].w + dist[src];
if (now == dist[v]) (ways[v] += ways[src]) %= mod;
else if (now < dist[v]) {
dist[v] = now; ways[v] = ways[src];
q.push({v, now});
}
}
while (!q.empty() && vis[q.top().v]) q.pop();
if (q.empty()) break;
vis[src = q.top().v] = true;
}
}
int main() {
memset(ne, -1, sizeof ne);
int m, s, t;
scanf("%d%d%d%d", &n,&m,&s,&t);
for (int i = 0; i < m; ++i) {
int u, v; LL w;
scanf("%d%d%lld", &u,&v,&w);
add(u, v, w), add(v, u, w);
}
dfs(s, dist1, ways1);
dfs(t, dist2, ways2);
assert(dist1[t] == dist2[s]);
assert(ways1[t] == ways2[s]);
LL ww = ways1[t];
LL ans = ww * (ww-1) % mod;
LL dis = dist1[t];
if (!(dis & 1)) {
LL half = dis >> 1;
for (int i = 1; i <= n; ++i) if (dist1[i] == half && dist2[i] == half) {
LL temp = ways1[i] * ways2[i] % mod;
ans = (ans - (temp * (temp-1)) % mod + mod) % mod;
}
}
for (int i = 0; i < m; ++i) {
int id = i<<1,
u = edge[id].from, v = edge[id].to;
if (dist1[u] > dist1[v]) swap(u, v);
if (dist1[u] + edge[id].w + dist2[v] == dis && (dist1[u]<<1) < dis && (dist2[v]<<1) < dis) {
LL temp = ways1[u] * ways2[v] % mod;
ans = (ans - (temp * (temp-1)) % mod + mod) % mod;
}
}
printf("%lld\n", ans);
return 0;
}
F - Number of Digits
见 http://www.cnblogs.com/kkkkahlua/p/8400712.html
AtCoder Regular Contest 090 C D E F的更多相关文章
- AtCoder Regular Contest 090 F - Number of Digits
题目链接 Description For a positive integer \(n\), let us define \(f(n)\) as the number of digits in bas ...
- AtCoder Regular Contest 090
C - Candies 链接:https://arc090.contest.atcoder.jp/tasks/arc090_a 题意:从左上角走到右下角,只能向右和向下走,问能最多能拿多少糖果. 思路 ...
- AtCoder Regular Contest 092 C D E F
C - 2D Plane 2N Points 题意 二维平面上有\(N\)个红点,\(N\)个蓝点,一个红点和一个蓝点能配成一对当且仅当\(x_r<x_b\)且\(y_r<y_b\). 问 ...
- AtCoder Regular Contest 090 D - People on a Line
D - People on a Line Problem Statement There are N people standing on the x-axis. Let the coordinate ...
- AtCoder Regular Contest 069 F Flags 二分,2-sat,线段树优化建图
AtCoder Regular Contest 069 F Flags 二分,2-sat,线段树优化建图 链接 AtCoder 大意 在数轴上放上n个点,点i可能的位置有\(x_i\)或者\(y_i\ ...
- AtCoder Regular Contest 061
AtCoder Regular Contest 061 C.Many Formulas 题意 给长度不超过\(10\)且由\(0\)到\(9\)数字组成的串S. 可以在两数字间放\(+\)号. 求所有 ...
- AtCoder Regular Contest 094 (ARC094) CDE题解
原文链接http://www.cnblogs.com/zhouzhendong/p/8735114.html $AtCoder\ Regular\ Contest\ 094(ARC094)\ CDE$ ...
- AtCoder Regular Contest 092
AtCoder Regular Contest 092 C - 2D Plane 2N Points 题意: 二维平面上给了\(2N\)个点,其中\(N\)个是\(A\)类点,\(N\)个是\(B\) ...
- AtCoder Regular Contest 093
AtCoder Regular Contest 093 C - Traveling Plan 题意: 给定n个点,求出删去i号点时,按顺序从起点到一号点走到n号点最后回到起点所走的路程是多少. \(n ...
随机推荐
- Linux-SSH远程登陆
SSH是什么 Secure Shell 安全外壳协议 建立在应用层基础上的安全协议 可靠.转为远程登陆会话和其他网络提供安全性的协议 SSH客户端是用于多种平台 服务器安装SSH服务 安装:yum i ...
- GNU汇编程序框架
汇编的作用:1.对芯片进行初始化 2. 和C混合编程提升C的运行效率 .section .data < 初始化的数据> .section .bss <未初始化的数据> .sec ...
- Centos7在运行yum命令时出现报错及排查处理过程
1.1 现象描述 Centos系统在正常重启后,运行yum命令安装软件工具的时候出现以下报错: cannot open Packages index using db5 - Structure ne ...
- java的重写(Override) (2013-10-11-163 写的日志迁移
/* *说明方法的重写(又称方法的覆盖)子类并不想原封不动地继承父类的方法,而是想作一定的修改 */ package czbk.jxy.study; /** * @author Archon * @d ...
- CodeForces 651B
#include <cstdio> #include <algorithm> using namespace std; int a[1005], n, temp, maxk; ...
- Vue之简易的留言板功能
今天我将带大家通过Vue的todolist案例来完成一个简易的网页留言板! LES'T GO! 首先我们需要在页面上搭建一个input文本输入框,并设置提交按钮,通过循环指令来完成输入框的信息提交! ...
- vue之小小动态按钮
Vue是前台框架,可以独立完成前后端分离式web项目渐进式的javascript框架 ,今天我们来设计一个简单的动态按钮 具体效果图如下: 点击后会变成这样: 首先我们需要下载vue.js:htt ...
- 如何在C#中调试LINQ查询
原文:How to Debug LINQ queries in C# 作者:Michael Shpilt 译文:如何在C#中调试LINQ查询 译者:Lamond Lu 在C#中我最喜欢的特性就是LIN ...
- 阿里云服务器+Tomcat项目+mysql 发布项目全过程
这个博客管理系统折腾我好几天了. 总结一下整个过程吧! 1.首先这个博客在tomcat下 windows系统可以完全跑起来了,无论是前台或者后台都能实现所有的功能. 2.然后我买了一个域名jasonj ...
- MySQL之Schema与数据类型优化
选择优化的数据类型 MySQL支持的数据类型非常多,选择正确的数据类型对于获得高性能至关重要.不管存储哪种类型的数据,下面几个简单的原则都有助于做出更好的选择: 更小的通常更好一般情况下,应该尽量使用 ...