当前位置:网站首页>LeetCode 1024 Video Stitching (dp,jump game)
LeetCode 1024 Video Stitching (dp,jump game)
2022-06-11 01:44:00 【_ TCgogogo_】
You are given a series of video clips from a sporting event that lasted time seconds. These video clips can be overlapping with each other and have varying lengths.
Each video clip is described by an array clips where clips[i] = [starti, endi] indicates that the ith clip started at starti and ended at endi.
We can cut these clips into segments freely.
- For example, a clip
[0, 7]can be cut into segments[0, 1] + [1, 3] + [3, 7].
Return the minimum number of clips needed so that we can cut the clips into segments that cover the entire sporting event [0, time]. If the task is impossible, return -1.
Example 1:
Input: clips = [[0,2],[4,6],[8,10],[1,9],[1,5],[5,9]], time = 10 Output: 3 Explanation: We take the clips [0,2], [8,10], [1,9]; a total of 3 clips. Then, we can reconstruct the sporting event as follows: We cut [1,9] into segments [1,2] + [2,8] + [8,9]. Now we have segments [0,2] + [2,8] + [8,10] which cover the sporting event [0, 10].
Example 2:
Input: clips = [[0,1],[1,2]], time = 5 Output: -1 Explanation: We cannot cover [0,5] with only [0,1] and [1,2].
Example 3:
Input: clips = [[0,1],[6,8],[0,2],[5,6],[0,4],[0,3],[6,7],[1,3],[4,7],[1,4],[2,5],[2,6],[3,4],[4,5],[5,7],[6,9]], time = 9 Output: 3 Explanation: We can take clips [0,4], [4,7], and [6,9].
Constraints:
1 <= clips.length <= 1000 <= starti <= endi <= 1001 <= time <= 100
Topic link :https://leetcode.com/problems/video-stitching/
The main idea of the topic : Yes n Intervals , Each section can be cut arbitrarily , Find at least a few intervals to cover [0, time]
Topic analysis : Create a new one nums Array , The length is max(clips[i].r),nums[clips[i].l] = clips[i].r - clips[i].l, After the conversion, the question becomes Jump Game and Jump Game Ⅱ Combination of two questions , Through the first Jump Game Judge whether there is a solution , Re pass Jump Game Ⅱ Solve it
0ms, Time beats 100%
class Solution {
private boolean ok(int[] nums, int time) {
int ma = 0;
for (int i = 0; i < time && ma >= i; i++) {
ma = Math.max(ma, i + nums[i]);
}
return ma >= time;
}
public int videoStitching(int[][] clips, int time) {
int n = 0;
for (int i = 0; i < clips.length; i++) {
n = Math.max(n, clips[i][1]);
}
n++;
int[] nums = new int[n];
for (int i = 0; i < clips.length; i++) {
int l = clips[i][0], r = clips[i][1];
nums[l] = Math.max(nums[l], r - l);
}
if (!ok(nums, time)) {
return -1;
}
int cur = 0, ma = 0, ans = 0;
for (int i = 0; i < time && cur < time; i++) {
ma = Math.max(ma, i + nums[i]);
if (cur == i) {
cur = ma;
ans++;
}
}
return ans;
}
}边栏推荐
- Set up a flag -- Reconstruct promise
- 2.0 detailed explanation of ROS and Px4 communication
- [Li mu] how to read papers [intensive reading of papers]
- Yunna provincial administrative unit fixed assets management system
- Project_ Visual analysis of epidemic data based on Web Crawler
- [path planning] week 1: hodgepodge
- 項目_基於網絡爬蟲的疫情數據可視化分析
- Leetcode 1574 shortest subarray to be removed to make array sorted
- [ROS introduction] cmakelist Txt and packages XML interpretation
- Using MySQL database in nodejs
猜你喜欢

PX4装机教程(六)垂起固定翼(倾转)
![[ROS] review of 2021 ROS Summer School](/img/1c/588d29b60071628c7c9fdce17e8b84.jpg)
[ROS] review of 2021 ROS Summer School

Understanding of multithreading

How to download web photos

There is a problem with numpy after CONDA installs pytoch

多兴趣召回模型实践|得物技术

Garbled code when the command parameter contains% in VisualStudio debugging

threejs:流光效果封装

中间件_Redis_05_Redis的持久化

Hao expresses his opinions: what small good habits have you adhered to?
随机推荐
Introduction to China patent award policy support, with a subsidy of 1million yuan
Introduction to support standards for specialized, special and new manufacturing enterprises in Chaoyang District, Beijing, with a subsidy of 1million yuan
1.2、ROS+PX4预备基础知识
Leetcode linked list queue stack problem
Lazy singleton mode
项目_基于网络爬虫的疫情数据可视化分析
What is the C-end and what is the b-end? Let me tell you
PX4装机教程(六)垂起固定翼(倾转)
SAS因子分析(proc factor过程和因子旋转以及回归法求因子得分函数)
From "0" to "tens of millions" concurrency, 14 technological innovations of Alibaba distributed architecture
Tencent cloud database tdsql- a big guy talks about the past, present and future of basic software
Introduction to the application process of Beijing China Patent Award, with a subsidy of 1million yuan
Clean up the broken artifacts data (.lastUpdated files) and reload the project. Problem resolution
Shenzhen Nanshan District specialized special new enterprise application process, with a subsidy of RMB 100000-500000
Application of object storage S3 in distributed file system
中间件_Redis_05_Redis的持久化
[ROS] review of 2021 ROS Summer School
Detectron2 trains its own dataset and converts it to coco format
ROS参数服务器
Introduction to the application process of China Patent Award, with a subsidy of 1million yuan