You are given an array of positive integers a1, a2, ..., an × T of length n × T. We know that for any i > n it is true that ai = ai - n. Find the length of the longest non-decreasing sequence of the given array.
The first line contains two space-separated integers: n, T (1 ≤ n ≤ 100, 1 ≤ T ≤ 107). The second line contains n space-separated integers a1, a2, ..., an (1 ≤ ai ≤ 300).
Print a single number — the length of a sought sequence.
4 3 3 1 4 2
5
The array given in the sample looks like that: 3, 1, 4, 2, 3, 1, 4, 2, 3, 1, 4, 2. The elements in bold form the largest non-decreasing subsequence.
发现肯定有一段是连续的相同的,因此我们先将序列复制n次,求出它的LIS然后再找出原序列中出现的次数最多的数插入在相应的位置。
#include <bits/stdc++.h> #define maxn 200005 using namespace std; int num[105], vis[305]; int d[10005]; int main(){ int n, t, maxs = 0;; scanf("%d%d", &n, &t); for(int i = 0; i < n; i++){ scanf("%d", num+i); vis[num[i]]++; maxs = max(maxs, vis[num[i]]); } int cnt = 0; for(int i = 0; i < min(n, t); i++) for(int j = 0; j < n; j++){ if(cnt == 0 || num[j] >= d[cnt-1]) d[cnt++] = num[j]; else{ int h = upper_bound(d, d+cnt, num[j]) - d; d[h] = num[j]; } } if(t > n) cnt += (t - n) * maxs; cout << cnt << endl; return 0; }