D. Deja vu of … Go Players

签。

 #include <bits/stdc++.h>
using namespace std;
int t, n, m; int main()
{
scanf("%d", &t);
while (t--)
{
scanf("%d%d", &n, &m);
for (int i = ; i <= n + m; ++i) scanf("%*d");
puts(n <= m ? "Yes" : "No");
}
return ;
}

I. Misunderstood … Missing

题意:

$有n轮游戏,每一轮有三个参数a_i, b_i, c_i$

初始攻击力为$A = 0, 成长值为D = 0$

每一轮的开头 $A = A + D$

接着三种操作选一个

  • 造成$A + a_i点伤害$
  • $D = D + b_i$
  • $A = A + c_i$

求造成的最大伤害和是多少

思路:

倒着$dp, dp[i][j][k] 表示当前处于第i轮,在后面的轮数中要进行j次攻击,时间点之和为k$

那么到当前点,我们就可以

通过$k\;来算出如果当前点选择第二种操作的贡献$

$dp[i][j][k] = max(dp[i][j][k], dp[i + 1][j][k] + c[i] * j)$

$通过j\;来算出如果当前点选择第三种操作的贡献$

$dp[i][j][k] = max(dp[i][j][k], dp[i + 1][j][k] + (k - i * j) * b[i])$

 #include <bits/stdc++.h>
using namespace std; #define ll long long
#define N 110
#define M 6010
int t, n;
ll dp[][N][M], a[N], b[N], c[N]; int main()
{
scanf("%d", &t);
while (t--)
{
scanf("%d", &n);
for (int i = ; i <= n; ++i) scanf("%lld%lld%lld", a + i, b + i, c + i);
for (int i = ; i < ; ++i) for (int j = ; j <= n; ++j) for (int k = ; k <= ; ++k) dp[i][j][k] = -;
dp[n & ^ ][][] = ;
for (int i = n; i >= ; --i)
{
for (int j = ; j <= n; ++j) for (int k = ; k <= ; ++k) if (dp[i & ^ ][j][k] != -)
{
dp[i & ][j + ][k + i] = max(dp[i & ][j + ][k + i], dp[i & ^ ][j][k] + a[i]);
dp[i & ][j][k] = max(dp[i & ][j][k], dp[i & ^ ][j][k] + 1ll * j * c[i]);
dp[i & ][j][k] = max(dp[i & ][j][k], dp[i & ^ ][j][k] + 1ll * (k - j * i) * b[i]);
}
}
ll res = ;
for (int i = ; i <= n; ++i) for (int j = ; j <= ; ++j) res = max(res, dp[][i][j]);
printf("%lld\n", res);
}
return ;
}

L. Eventual … Journey

题意:

有两个阵营,阵营之间的人可以两两之间通过花费1来相互到达

不同阵营之间如果有直接边也可以直接相互到达,如果没有直接边,可以通过间接到达

即先到达一个有边连到对方阵营的同阵营的人,再过去

思路:

考虑花费一共有三种情况

1:同阵营之间的相互到达,不同阵营之间有边可以直接到达

2:不同阵营之间没有直接边,但是有一方有直接边连向对方阵营

3:两个属于不同阵营,且都没有直接边连向对方阵营

要注意m = 0的时候,不同阵营之间不可达

还有 它给出的公共边可能有相同阵营的

 #include <bits/stdc++.h>
using namespace std; #define N 100010
int n, m;
int cnt[], zero[], degree[N], vis[N]; int main()
{
while (scanf("%d%d", &n, &m) != EOF)
{
memset(degree, , sizeof degree);
cnt[] = cnt[] = ;
zero[] = zero[] = ;
for (int i = ; i <= n; ++i)
{
scanf("%d", vis + i);
++cnt[vis[i]];
}
if (m == )
{
for (int i = ; i <= n; ++i) printf("%d%c", cnt[vis[i]] - , " \n"[i == n]);
continue;
}
for (int i = , u, v; i <= m; ++i)
{
scanf("%d%d", &u, &v);
if (vis[u] == vis[v]) continue;
++degree[u];
++degree[v];
}
for (int i = ; i <= n; ++i) if (!degree[i])
++zero[vis[i]];
for (int i = ; i <= n; ++i)
{
int res = ;
if (degree[i]) res = cnt[vis[i]] - + degree[i] + (cnt[vis[i] ^ ] - degree[i]) * ;
else res = cnt[vis[i]] - + cnt[vis[i] ^ ] * + zero[vis[i] ^ ];
printf("%d%c", res, " \n"[i == n]);
}
}
return ;
}

2018-2019 ACM-ICPC, Asia East Continent Finals Solution的更多相关文章

  1. 训练20191009 2018-2019 ACM-ICPC, Asia East Continent Finals

    2018-2019 ACM-ICPC, Asia East Continent Finals 总体情况 本次训练共3小时20分钟,通过题数4. 解题报告 D. Deja vu of - Go Play ...

  2. 2018-2019 ACM-ICPC, Asia East Continent Finals I. Misunderstood … Missing(dp)

    题目链接: http://codeforces.com/gym/102056/problem/I 题意: 人物有l两个属性分别是$A,D$ 每个回合人物$A\pm D$ 每个回合有三个选择分别是: 1 ...

  3. 2018-2019 ACM-ICPC, Asia East Continent Finals部分题解

    C:显然每p2个数会有一个0循环,其中22 32 52 72的循环会在200个数中出现,找到p2循环的位置就可以知道首位在模p2意义下是多少,并且循环位置几乎是唯一的(对72不满足但可能的位置也很少) ...

  4. 2019 ACM/ICPC Asia Regional shanxia D Miku and Generals (二分图黑白染色+01背包)

    Miku is matchless in the world!” As everyone knows, Nakano Miku is interested in Japanese generals, ...

  5. 2017 ACM/ICPC Asia Regional Qingdao Online Solution

    A : Apple 题意:给出三个点,以及另一个点,求最后一个点是否在三个点的外接圆里面,如果在或者在边界上,输出“Rejected”,否则输出"Accepted" 思路:先求一个 ...

  6. 2016 ACM/ICPC Asia Regional Shenyang Online 1009/HDU 5900 区间dp

    QSC and Master Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) ...

  7. hdu 5444 Elven Postman(二叉树)——2015 ACM/ICPC Asia Regional Changchun Online

    Problem Description Elves are very peculiar creatures. As we all know, they can live for a very long ...

  8. (二叉树)Elven Postman -- HDU -- 54444(2015 ACM/ICPC Asia Regional Changchun Online)

    http://acm.hdu.edu.cn/showproblem.php?pid=5444 Elven Postman Time Limit: 1500/1000 MS (Java/Others)  ...

  9. 2015 ACM/ICPC Asia Regional Changchun Online HDU 5444 Elven Postman【二叉排序树的建树和遍历查找】

    Elven Postman Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

随机推荐

  1. linux复制文件到指定的文件夹

    copy命令      该命令的功能是将给出的文件或目录拷贝到另一文件或目录中,同MSDOS下的copy命令一样,功能十分强大. 语法: cp [选项] 源文件或目录 目标文件或目录 说明:该命令把指 ...

  2. 64位ubuntu下用code::blocks IDE配置opengl开发环境

    http://jingyan.baidu.com/article/c74d60007d104f0f6b595d6d.html 样例程序: #include <GL/glut.h> #inc ...

  3. Spring 工作流程简单介绍

    Spring Web MVC 处理Http请求的大致过程: 一旦Http请求到来,DispatcherSevlet将负责将请求分发. DispatcherServlet可以认为是Spring提供的前端 ...

  4. 《转》python学习(3)

    转自http://www.cnblogs.com/BeginMan/archive/2013/06/03/3114974.html 1.print语句调用str()函数显示,交互式解释器调用repr( ...

  5. MyBatis官方文档——XML 映射配置文件

    XML 映射配置文件 MyBatis 的配置文件包含了影响 MyBatis 行为甚深的设置(settings)和属性(properties)信息.文档的顶层结构如下: configuration 配置 ...

  6. JZOJ.5325【NOIP2017模拟8.21】九九归一

    Description

  7. PMP 笔记

    项目: 为创造独特的产品.服务或结果而进行的临时性工作. 项目特征: 独特性:Unique.临时性:Temporary.渐进明细. 渐进明细:预算越来越精细.比如三峡工程中,预算从10亿级的误差到1亿 ...

  8. iPad - 开发(Universal Applications)

    一.iPad 1.判断是否在iPad上 BOOL iPad = ([[UIDevice currentDevice] userInterfaceIdiom] == UIUserInterfaceIdi ...

  9. 一键搞定JavaEE应用,JRE+Tomcat+Mysql-JaveEE绿色运行环境JTM0.9版 (转载)

    这是一个集成了jre,tomcat,mysql的绿色运行环境, 直接解压之后就可以运行.不需要用户自己安装jre,tomcat,mysql,一键到位,看起来像是桌面式的web应用.换句话说,就像是we ...

  10. 【css预处理器】------sass的基本语法------【巷子】

    001.安装sass 1.删除gem源:gem sources --remove https://rubygems.org/ 2.添加国内源:gem sources -a http://gems.ru ...