Điểm:
1600 (p)
Thời gian:
1.0s
Bộ nhớ:
512M
Input:
bàn phím
Output:
màn hình
Bạn được cho một mảng gồm \(n\) số nguyên. Nhiệm vụ của bạn là xác định dãy con tăng dài nhất của mảng, tức là, tìm dãy con dài nhất trong đó tất cả các phần tử đều lớn hơn phần tử trước đó.
Một dãy con là một dãy có thể thu được từ mảng bằng cách xóa một số phần tử mà vẫn không thay đổi thứ tự của các phần tử còn lại.
Input
- Dòng đầu tiên chứa một số nguyên \(n\) \((1 \leq n \leq 2 \times 10^{5})\) - kích thước của mảng.
- Sau đó có \(n\) số nguyên \(x_{1}, x_{2}, \dots, x_{n}\) \((1 \leq x_{i} \leq 10^{9})\) - các phần tử của mảng.
Output
- In độ dài của dãy con tăng dài nhất.
Example
Test 1
Input
8
7 3 5 3 6 2 9 8
Output
4
Bình luận
code cho ai cần nè !
include<bits/stdc++.h>
using namespace std;
define ll int64_t
ll n,a[200006],k,j,l[200006];
int main(){
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin>>n;
for (int i=1;i<=n;i++){
cin>>a[i];
}
for (int i=1;i<=n;i++){
j=lower_bound(l+1,l+k+1,a[i])-l-1;
l[j+1]=a[i];
k=max(k,j+1);
}
cout<<k;
return 0;
}
giống bài Dãy con tăng dài nhất(bản khó)
tăng thời gian cko python đc ko vậy
Bài này là một bài QHĐ khá kinh điển và bị trùng khá nhiều trên trang rồi