🗒️2211. 统计道路上的碰撞次数
2025-5-28
| 2025-5-28
0  |  阅读时长 0 分钟
type
status
date
slug
summary
tags
category
icon
password
创建时间
May 28, 2025 05:17 AM
在一条无限长的公路上有 n 辆汽车正在行驶。汽车按从左到右的顺序按从 0 到 n - 1 编号,每辆车都在一个 独特的 位置。
给你一个下标从 0 开始的字符串 directions ,长度为 n 。directions[i] 可以是 'L''R' 或 'S' 分别表示第 i 辆车是向  、向  或者 停留 在当前位置。每辆车移动时 速度相同 。
碰撞次数可以按下述方式计算:
  • 当两辆移动方向 相反 的车相撞时,碰撞次数加 2 。
  • 当一辆移动的车和一辆静止的车相撞时,碰撞次数加 1 。
碰撞发生后,涉及的车辆将无法继续移动并停留在碰撞位置。除此之外,汽车不能改变它们的状态或移动方向。
返回在这条道路上发生的 碰撞总次数 。

三、栈§3.3 邻项消除

简洁写法,参考 灵茶山艾府。思路和我差不多,先将首尾不可能相撞的车去掉,讨论中间的车。这里巧妙的是直接统计非停止的车。实在是妙!!!
我讨论了好多种情况,没想到大道至简。
我更改后的代码
更简洁的写法
常用的栈模拟套路——newhar

📎 参考

 
  • 【题单】常用数据结构(前缀和/差分/栈/队列/堆/字典树/并查集/树状数组/线段树)
  • Important
  • 735. 小行星碰撞1209. 删除字符串中的所有相邻重复项 II
    Loading...