From 3082210f43f8e4a17606d4415460e3a2a2f31b30 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=BD=A9=E8=BE=95=E9=BE=99=E5=84=BF?= Date: Thu, 31 Mar 2022 13:48:48 +0800 Subject: [PATCH] =?UTF-8?q?/2100:=E9=80=82=E5=90=88=E6=89=93=E5=8A=AB?= =?UTF-8?q?=E9=93=B6=E8=A1=8C=E7=9A=84=E6=97=A5=E5=AD=90?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../editor/cn/FindGoodDaysToRobTheBank.java | 97 +++++++++++++++++++ .../doc/content/FindGoodDaysToRobTheBank.md | 55 +++++++++++ 2 files changed, 152 insertions(+) create mode 100644 src/main/java/leetcode/editor/cn/FindGoodDaysToRobTheBank.java create mode 100644 src/main/java/leetcode/editor/cn/doc/content/FindGoodDaysToRobTheBank.md diff --git a/src/main/java/leetcode/editor/cn/FindGoodDaysToRobTheBank.java b/src/main/java/leetcode/editor/cn/FindGoodDaysToRobTheBank.java new file mode 100644 index 0000000..9469541 --- /dev/null +++ b/src/main/java/leetcode/editor/cn/FindGoodDaysToRobTheBank.java @@ -0,0 +1,97 @@ +//你和一群强盗准备打劫银行。给你一个下标从 0 开始的整数数组 security ,其中 security[i] 是第 i 天执勤警卫的数量。日子从 0 开始 +//编号。同时给你一个整数 time 。 +// +// 如果第 i 天满足以下所有条件,我们称它为一个适合打劫银行的日子: +// +// +// 第 i 天前和后都分别至少有 time 天。 +// 第 i 天前连续 time 天警卫数目都是非递增的。 +// 第 i 天后连续 time 天警卫数目都是非递减的。 +// +// +// 更正式的,第 i 天是一个合适打劫银行的日子当且仅当:security[i - time] >= security[i - time + 1] >= .. +//. >= security[i] <= ... <= security[i + time - 1] <= security[i + time]. +// +// 请你返回一个数组,包含 所有 适合打劫银行的日子(下标从 0 开始)。返回的日子可以 任意 顺序排列。 +// +// +// +// 示例 1: +// +// +//输入:security = [5,3,3,3,5,6,2], time = 2 +//输出:[2,3] +//解释: +//第 2 天,我们有 security[0] >= security[1] >= security[2] <= security[3] <= +//security[4] 。 +//第 3 天,我们有 security[1] >= security[2] >= security[3] <= security[4] <= +//security[5] 。 +//没有其他日子符合这个条件,所以日子 2 和 3 是适合打劫银行的日子。 +// +// +// 示例 2: +// +// +//输入:security = [1,1,1,1,1], time = 0 +//输出:[0,1,2,3,4] +//解释: +//因为 time 等于 0 ,所以每一天都是适合打劫银行的日子,所以返回每一天。 +// +// +// 示例 3: +// +// +//输入:security = [1,2,3,4,5,6], time = 2 +//输出:[] +//解释: +//没有任何一天的前 2 天警卫数目是非递增的。 +//所以没有适合打劫银行的日子,返回空数组。 +// +// +// +// +// 提示: +// +// +// 1 <= security.length <= 10⁵ +// 0 <= security[i], time <= 10⁵ +// +// Related Topics 数组 动态规划 前缀和 👍 126 👎 0 + +package leetcode.editor.cn; + +import java.util.ArrayList; +import java.util.List; + +//2100:适合打劫银行的日子 +public class FindGoodDaysToRobTheBank { + public static void main(String[] args) { + Solution solution = new FindGoodDaysToRobTheBank().new Solution(); + // TO TEST + } + + //leetcode submit region begin(Prohibit modification and deletion) + class Solution { + public List goodDaysToRobBank(int[] security, int time) { + int n = security.length; + int[] left = new int[n], right = new int[n]; + for (int i = 1; i < n; i++) { + if (security[i - 1] >= security[i]) { + left[i] = left[i - 1] + 1; + } + if (security[n - i] >= security[n - 1 - i]) { + right[n - 1 - i] = right[n - i] + 1; + } + } + List list = new ArrayList<>(); + for (int i = 0; i < n; i++) { + if (left[i] >= time && right[i] >= time) { + list.add(i); + } + } + return list; + } + } +//leetcode submit region end(Prohibit modification and deletion) + +} diff --git a/src/main/java/leetcode/editor/cn/doc/content/FindGoodDaysToRobTheBank.md b/src/main/java/leetcode/editor/cn/doc/content/FindGoodDaysToRobTheBank.md new file mode 100644 index 0000000..cc15be6 --- /dev/null +++ b/src/main/java/leetcode/editor/cn/doc/content/FindGoodDaysToRobTheBank.md @@ -0,0 +1,55 @@ +

你和一群强盗准备打劫银行。给你一个下标从 0 开始的整数数组 security ,其中 security[i] 是第 i 天执勤警卫的数量。日子从 0 开始编号。同时给你一个整数 time 。

+ +

如果第 i 天满足以下所有条件,我们称它为一个适合打劫银行的日子:

+ +
    +
  • i 天前和后都分别至少有 time 天。
  • +
  • i 天前连续 time 天警卫数目都是非递增的。
  • +
  • i 天后连续 time 天警卫数目都是非递减的。
  • +
+ +

更正式的,第 i 天是一个合适打劫银行的日子当且仅当:security[i - time] >= security[i - time + 1] >= ... >= security[i] <= ... <= security[i + time - 1] <= security[i + time].

+ +

请你返回一个数组,包含 所有 适合打劫银行的日子(下标从 0 开始)。返回的日子可以 任意 顺序排列。

+ +

 

+ +

示例 1:

+ +
+输入:security = [5,3,3,3,5,6,2], time = 2
+输出:[2,3]
+解释:
+第 2 天,我们有 security[0] >= security[1] >= security[2] <= security[3] <= security[4] 。
+第 3 天,我们有 security[1] >= security[2] >= security[3] <= security[4] <= security[5] 。
+没有其他日子符合这个条件,所以日子 2 和 3 是适合打劫银行的日子。
+
+ +

示例 2:

+ +
+输入:security = [1,1,1,1,1], time = 0
+输出:[0,1,2,3,4]
+解释:
+因为 time 等于 0 ,所以每一天都是适合打劫银行的日子,所以返回每一天。
+
+ +

示例 3:

+ +
+输入:security = [1,2,3,4,5,6], time = 2
+输出:[]
+解释:
+没有任何一天的前 2 天警卫数目是非递增的。
+所以没有适合打劫银行的日子,返回空数组。
+
+ +

 

+ +

提示:

+ +
    +
  • 1 <= security.length <= 105
  • +
  • 0 <= security[i], time <= 105
  • +
+
Related Topics
  • 数组
  • 动态规划
  • 前缀和

  • 👍 126
  • 👎 0
  • \ No newline at end of file