比赛链接:Here

ABC水题,

D - Multiple of 2019 (DP + 分析)

题意:

给定数字串S,计算有多少个子串 \(S[L,R]\)​ ,满足 \(S[L,R]\) 是 \(2019\) 的倍数

思路:

\(s[l, r] * 10^{n-r}=s[l, n]-s[r+1, n]\)

而且 \(s[l, r] * 10^{n-r} = s[l,r]\%2019*(10^{n-r}\%2019)\)

因为 \(10^{n-r}\%2019 \not =0\) (因为 \(2019\) 没有质因子 \(2\) 和 \(5\) )

因此只有当 \(s[l,r]\%2019 = 0\) 时,式子左边 \(=0\) ,这意味着 \(10^{n-r}\) 没有影响,

那么直接计算 \(s[l, n] \% 2019-s[r+1, n] \% 2019=0\) 的数量即可,

因为这种情况下一定是 \(s[l,r] =0\)

int a[2040] = {1};
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
string s; cin >> s;
int ans = 0, t = 1, cnt = 0;
for (int i = s.size() - 1; ~i; i--) {
cnt = (cnt + t * (s[i] - '0')) % 2019;
ans += a[cnt]++;
t = (t * 10) % 2019;
}
cout << ans;
}

E Two Currencies (最短路,Good)

题意:

给定 \(n\) 个点,\(m\) 条无向边,初始状态下手里有 \(s\) 个银币。从 \(u\) 点到 \(v\) 点需要花费 \(a\) 个硬币,\(b\) 个时间单位。在每个点可以花 \(d\) 个时间单位兑换 \(c\) 个银币,求从起点 \(1\) 到各个点需要的最短时间。

思路:

这题很关键的一个突破口是数据范围:\(50\)​​ 个点,从 \(u\)​​ 到 \(v\)​​ 花费不超过 \(50\)​​ 银币,所以总花费不超过\(2500\)​ .通过一个二维数组 \(dis[ i ][ j ]\)​ 来表示到达 \(i\) 点时还剩下 \(j\) 个银币时需要的时间最小值,然后跑一遍最短路,最后遍历一遍就可以输出最小值。

注意银币最大只需要 \(2500\) ,所以输入 \(s\) 的时候记得判断

struct E {ll to, co, ti;};
struct P {ll ti, id, re;};
bool operator <(const P &a, const P &b) {return a.ti > b.ti;}
ll f[50][5001], c[50], d[50], ans[50];
vector<E>e[50];
priority_queue<P> que;
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int n, m, s;
cin >> n >> m >> s;
while (m--) {
ll u, v, a, b;
cin >> u >> v >> a >> b;
u--, v--;
e[u].push_back({v, a, b});
e[v].push_back({u, a, b});
}
for (int i = 0; i < n; ++i) cin >> c[i] >> d[i];
que.push({1, 0, min(s * 1ll, 2500ll)});
while (que.size()) {
P p = que.top(); que.pop();
if (f[p.id][p.re])continue;
f[p.id][p.re] = p.ti;
if (!ans[p.id])ans[p.id] = p.ti;
for (E q : e[p.id])
if (p.re >= q.co && !f[q.to][p.re - q.co])
que.push({p.ti + q.ti, q.to, p.re - q.co});
if (p.re + c[p.id] <= 2500)
que.push({p.ti + d[p.id], p.id, p.re + c[p.id]});
}
for (int i = 1; i < n; ++i) cout << --ans[i] << "\n";
}

AtCoder ABC 164 (D~E)的更多相关文章

  1. ATCODER ABC 099

    ATCODER ABC 099 记录一下自己第一场AK的比赛吧...虽然还是被各种踩... 只能说ABC确实是比较容易. A 题目大意 给你一个数(1~1999),让你判断它是不是大于999. Sol ...

  2. Atcoder ABC 141

    Atcoder ABC 141 A - Weather Prediction SB题啊,不讲. #include<iostream> #include<cstdio> #inc ...

  3. Atcoder ABC 139E

    Atcoder ABC 139E 题意: n支球队大循环赛,每支队伍一天只能打一场,求最少几天能打完. 解法: 考虑抽象图论模型,既然一天只能打一场,那么就把每一支球队和它需要交手的球队连边. 求出拓 ...

  4. Atcoder ABC 139D

    Atcoder ABC 139D 解法: 等差数列求和公式,记得开 $ long long $ CODE: #include<iostream> #include<cstdio> ...

  5. Atcoder ABC 139C

    Atcoder ABC 139C 题意: 有 $ n $ 个正方形,选择一个起始位置,使得从这个位置向右的小于等于这个正方形的高度的数量最多. 解法: 简单递推. CODE: #include< ...

  6. Atcoder ABC 139B

    Atcoder ABC 139B 题意: 一开始有1个插口,你的插排有 $ a $ 个插口,你需要 $ b $ 个插口,问你最少需要多少个插排. 解法: 暴力模拟. CODE: #include< ...

  7. Atcoder ABC 139A

    Atcoder ABC 139A 题意: 给你两个字符串,记录对应位置字符相同的个数 $ (n=3) $ 解法: 暴力枚举. CODE: #include<iostream> #inclu ...

  8. atcoder abc 244

    atcoder abc 244 D - swap hats 给定两个 R,G,B 的排列 进行刚好 \(10^{18}\) 次操作,每一次选择两个交换 问最后能否相同 刚好 \(10^{18}\) 次 ...

  9. AtCoder ABC 250 总结

    AtCoder ABC 250 总结 总体 连续若干次一样的结果:30min 切前 4 题,剩下卡在 T5 这几次卡在 T5 都是一次比一次接近, 什么 dp 前缀和打挂,精度被卡,能水过的题连水法都 ...

  10. AtCoder ABC 242 题解

    AtCoder ABC 242 题解 A T-shirt 排名前 \(A\) 可得 T-shirt 排名 \([A+1,B]\) 中随机选 \(C\) 个得 T-shirt 给出排名 \(X\) ,求 ...

随机推荐

  1. 【scipy 基础】--稀疏矩阵

    稀疏矩阵是一种特殊的矩阵,其非零元素数目远远少于零元素数目,并且非零元素分布没有规律.这种矩阵在实际应用中经常出现,例如在物理学.图形学和网络通信等领域. 稀疏矩阵其实也可以和一般的矩阵一样处理,之所 ...

  2. 主数据管理系统(MDM)集成方案

    在当今社会,数据已成为企业发展的宝贵财富.然而,大多数企业面临着数据散落在多个系统中.无法互相印证和共享的问题,导致数据使用效率低下.为解决这个问题,目前有两种典型途径:建设公司级系统或建立数据共享平 ...

  3. Codeforces Round 894 (Div. 3)

    Codeforces Round 894 (Div. 3) A. Gift Carpet 题意:判断一列一个字母有没有"vika" 思路:挨个枚举每一列 #include<b ...

  4. 轻量级SpringBoot配置中心 - Minimal-Config

    介绍 minimal-config-spring-boot-starter,是基于Spring-Boot原生配置注入实现原理的基础上,拓展的轻量级配置中心,项目体积只有24KB,设计理念为服务中小型项 ...

  5. 吉特日化MES & SQL Server 无法执行数据库脚本

    打开服务器打算远程执行一下脚本,突发发现数据库无法执行脚本,就想着是不是安装了 海康AGV 控制系统的问题导致,问题如下: 问题截图如下: 报错信息如下: ====================== ...

  6. WPF 入门基础

    关于 WPF 和 XAML 什么是 WPF WPF(Windows Presentation Foundation)是由微软开发的桌面应用程序框架,用于创建现代化.高度交互和具有视觉吸引力的用户界面. ...

  7. idea用不了 idea.bat文件闪退

    由于idea的智能,在破解之后会留下一些问题,根据网上搜出来的解决办法. 1.C:\Users\dell\AppData\Roaming\JetBrains\IntelliJIdea2022.2 在这 ...

  8. SpringCloud Gateway 网关

    SpringCloud Gateway 网关 spring: cloud: gateway: routes: - id: after_route uri: https://example.org pr ...

  9. Python笔记二之多线程

    本文首发于公众号:Hunter后端 原文链接:Python笔记二之多线程 这一篇笔记介绍一下在 Python 中使用多线程. 注意:以下的操作都是在 Python 3.8 版本中试验,不同版本可能有不 ...

  10. Redis 使用的 10 个小技巧

    Redis 在当前的技术社区里是非常热门的.从来自 Antirez 一个小小的个人项目到成为内存数据存储行业的标准,Redis已经走过了很长的一段路. 随之而来的一系列最佳实践,使得大多数人可以正确地 ...