이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
#define eb emplace_back
#define pb push_back
#define ppb pop_back
#define ub upper_bound
#define lb lower_bound
#define bs binary_search
#define cl(a,s) memset((a),0,sizeof((a)[0])*(s))
#define all(x) (x).begin() , (x).end()
#define fi first
#define se second
#define int int
using pii = pair<int,int>;
using ll = long long;
const int maxn = 2005;
const int maxq = 105;
const int inf = 1e9;
const int mod = 1e9+7;
int n,a[maxn],l,q;
int ans[maxn][maxq];
int k[maxq];
int dist(int ind1 ,int ind2) {
int cnt = 0;
for(int i=ind1;i<=ind1+l-1;i++)
if(a[i] != a[ind2+i-ind1])
cnt++;
return cnt;
}
int32_t main () {
//freopen("in","r",stdin); freopen("out","w",stdout);
ios_base::sync_with_stdio(0); cout.tie(0); cin.tie(0);
cin >> n >> l;
for(int i=1;i<=n;i++) cin >> a[i];
cin >> q;
for(int i=1;i<=q;i++) cin >> k[i];
for(int i=1;i+l-1<=n;i++)
for(int j=i+1;j+l-1<=n;j++) {
int res = dist(i,j);
for(int m=q;m>=1;m--) {
if(res > k[m]) continue;
ans[i][m]++;
ans[j][m]++;
}
}
for(int i=1;i<=q;i++,cout << endl)
for(int j=1;j+l-1<=n;j++)
cout << ans[j][i] << " ";
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |