返回介绍

solution / 2200-2299 / 2211.Count Collisions on a Road / README

发布于 2024-06-17 01:03:08 字数 3578 浏览 0 评论 0 收藏 0

2211. 统计道路上的碰撞次数

English Version

题目描述

在一条无限长的公路上有 n 辆汽车正在行驶。汽车按从左到右的顺序按从 0n - 1 编号,每辆车都在一个 独特的 位置。

给你一个下标从 0 开始的字符串 directions ,长度为 ndirections[i] 可以是 'L''R''S' 分别表示第 i 辆车是向 、向 或者 停留 在当前位置。每辆车移动时 速度相同

碰撞次数可以按下述方式计算:

  • 当两辆移动方向 相反 的车相撞时,碰撞次数加 2
  • 当一辆移动的车和一辆静止的车相撞时,碰撞次数加 1

碰撞发生后,涉及的车辆将无法继续移动并停留在碰撞位置。除此之外,汽车不能改变它们的状态或移动方向。

返回在这条道路上发生的 碰撞总次数

 

示例 1:

输入:directions = "RLRSLL"
输出:5
解释:
将会在道路上发生的碰撞列出如下:
- 车 0 和车 1 会互相碰撞。由于它们按相反方向移动,碰撞数量变为 0 + 2 = 2 。
- 车 2 和车 3 会互相碰撞。由于 3 是静止的,碰撞数量变为 2 + 1 = 3 。
- 车 3 和车 4 会互相碰撞。由于 3 是静止的,碰撞数量变为 3 + 1 = 4 。
- 车 4 和车 5 会互相碰撞。在车 4 和车 3 碰撞之后,车 4 会待在碰撞位置,接着和车 5 碰撞。碰撞数量变为 4 + 1 = 5 。
因此,将会在道路上发生的碰撞总次数是 5 。

示例 2:

输入:directions = "LLRR"
输出:0
解释:
不存在会发生碰撞的车辆。因此,将会在道路上发生的碰撞总次数是 0 。

 

提示:

  • 1 <= directions.length <= 105
  • directions[i] 的值为 'L''R''S'

解法

方法一

class Solution:
  def countCollisions(self, directions: str) -> int:
    d = directions.lstrip('L').rstrip('R')
    return len(d) - d.count('S')
class Solution {
  public int countCollisions(String directions) {
    char[] ds = directions.toCharArray();
    int n = ds.length;
    int l = 0;
    int r = n - 1;
    while (l < n && ds[l] == 'L') {
      ++l;
    }
    while (r >= 0 && ds[r] == 'R') {
      --r;
    }
    int ans = 0;
    for (int i = l; i <= r; ++i) {
      if (ds[i] != 'S') {
        ++ans;
      }
    }
    return ans;
  }
}
class Solution {
public:
  int countCollisions(string directions) {
    int l = 0, r = directions.size() - 1, count = 0;
    while (l <= r && directions[l] == 'L') {
      l++;
    }
    while (l <= r && directions[r] == 'R') {
      r--;
    }
    for (int i = l; i <= r; i++) {
      count += directions[i] != 'S';
    }
    return count;
  }
};
func countCollisions(directions string) int {
  d := strings.TrimLeft(directions, "L")
  d = strings.TrimRight(d, "R")
  return len(d) - strings.Count(d, "S")
}
function countCollisions(directions: string): number {
  const n = directions.length;
  let l = 0,
    r = n - 1;
  while (l < n && directions[l] == 'L') {
    ++l;
  }
  while (r >= 0 && directions[r] == 'R') {
    --r;
  }
  let ans = 0;
  for (let i = l; i <= r; ++i) {
    if (directions[i] != 'S') {
      ++ans;
    }
  }
  return ans;
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文