当前位置: 首页 > news >正文

D. Traffic Lights 【Codeforces Round 1038, Div. 1 + Div. 2】

D. Traffic Lights

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

思路

可以证明从1到n的总时间不超过 3n3n3n (见证明)
bfs时间步进模拟​​运动即可,时间复杂度是 O(n2)O(n^2)O(n2)

代码

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
#define endl '\n'
#define int long long
#define pb emplace_back
#define pii pair<int, int>
#define FU(i, a, b) for (int i = (a); i <= (b); ++i)
#define FD(i, a, b) for (int i = (a); i >= (b); --i)
const int MOD = 1e9 + 7;
const int INF = 0x3f3f3f3f;
const int MAXN = 5005;vector<int> G[MAXN];
int d[MAXN];  // 到达节点u的最小等待次数
int nd[MAXN]; // 临时数组,用于存储下一个时间步的状态void solve() {int n, m;cin >> n >> m;for (int i = 0; i <= n; i++) {G[i].clear();}FU(i, 1, m) {int u, v;cin >> u >> v;G[u].pb(v);G[v].pb(u);}memset(d, INF, sizeof(int) * (n + 2));d[1] = 0;int tm = 0;while (d[n] >= INF) {// 等待for (int j = 1; j <= n; j++) {nd[j] = d[j] + 1;}// 移动for (int j = 1; j <= n; j++) {if (d[j] == INF)continue;int nx = G[j][tm % G[j].size()];if (d[j] < nd[nx]) {nd[nx] = d[j];}}memcpy(d, nd, sizeof(int) * (n + 2));tm++;}cout << tm << " " << d[n] << '\n';
}signed main() {
#ifndef ONLINE_JUDGEfreopen("../in.txt", "r", stdin);
#endif// cin.tie(0)->ios::sync_with_stdio(0);int T = 1;cin >> T;while (T--) {solve();}return 0;
}
http://www.lryc.cn/news/594292.html

相关文章:

  • docker制作前端镜像
  • securecrt连接服务器报错 Key exchange failed 怎么办
  • Direct3D 11学习(一)
  • 股票账户数据及其数据获取
  • Python dataclass 高阶用法与技巧
  • ADC和DMA简述
  • Java中List<int[]>()和List<int[]>[]的区别
  • k8s:离线添加集群节点
  • MySQL—表设计和聚合函数以及正则表达式
  • 【性能测试】性能压测3个阶段+高频面试题回答(详细)
  • 第三章自定义检视面板_创建自定义编辑器类_编辑器操作的撤销与恢复(本章进度3/9)
  • Android 项目中如何在执行 assemble 或 Run 前自动执行 clean 操作?
  • Milvus Dify 学习笔记
  • Unity学习笔记(五)——3DRPG游戏(2)
  • 正点原子stm32F407学习笔记10——输入捕获实验
  • 【no vue no bug】 npm : 无法加载文件 D:\software\nodeJS\node22\npm.ps1
  • ansible awx自动化工具学习准备
  • [学习] 深入理解傅里叶变换:从时域到频域的桥梁
  • 【1】计算机视觉方法(更新)
  • 算法-递推
  • C++ 并发 future, promise和async
  • 设计模式笔记(1)简单工厂模式
  • 基于单片机的自动条幅悬挂机
  • Linux文件系统底层原理:从磁盘物理结构到LBA寻址
  • MySQL锁(一) 概述与分类
  • springboot03-一个简单的SSMP框架
  • MySQL详解三
  • 详解Mysql HashJoin加速原理
  • 乐观锁实现原理笔记
  • LINUX入门(二)QT的安装及运行环境搭建