This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
//#include "paint.h"
//#include <ext/pb_ds/assoc_container.hpp>
//#include <ext/pb_ds/tree_policy.hpp>
//#pragma GCC optimize("unroll-loops")
//#pragma GCC optimize("-O3")
//#pragma GCC optimize("Ofast")
//#pragma GCC optimize("fast-math")
//#pragma GCC optimize("no-stack-protector")
#define N 100100
#define F first
#define S second
#define M ll(1e9 + 7)
#define endl '\n'
#define all(x) x.begin(), x.end()
#define PB push_back
#define sz(x) ll(x.size())
#define pw(x) (1ll << x)
#define pwr(x) ((1ll << x) - 1)
#define _ << " " <<
#define pri(s) cout << s << endl
using namespace std;
//using namespace __gnu_pbds;
typedef long long ll;
typedef long double ld;
typedef short int si;
typedef unsigned long long ull;
//typedef tree<int, null_type, less <int>, rb_tree_tag, tree_order_statistics_node_update> ordered_set;
int minimumInstructions(int n, int m, int k, vector<int> c, vector<int> a, vector<vector<int> > b)
{
int who[k];
for (int i = 0; i < k; i++) who[i] = -1;
for (int i = 0; i < m; i++)
for (auto it : b[i]) who[it] = i;
for (int i = 0; i < n; i++) {a[i] = who[a[i]]; if (a[i] == -1) return -1;}
bool mk[n];
memset(mk, 0, sizeof mk);
for (int i = 0; i < n; i++)
if (a[i] == 0)
{
int len = 0;
bool bad = 0;
int cur = i;
while (len < m && cur < n)
{
if (a[cur] != len) {bad = 1; break;}
len++;
cur++;
}
if (len != m) bad = 1;
if (!bad)
{
len = 0;
cur = i;
while (len < m)
{
mk[cur] = 1;
len++;
cur++;
}
}
bad = 0;
len = 0;
int j = 0;
cur = i;
while (len < m && cur >= 0)
{
if (a[cur] != j) {bad = 1; break;}
len++; j--; j += m; j %= m;
cur--;
}
if (len != m) bad = 1;
if (!bad)
{
len = 0;
j = 0;
cur = i;
while (len < m)
{
mk[cur] = 1;
len++; j--; j += m; j %= m;
cur--;
}
}
}
for (int i = 0; i < n; i++) if (!mk[i]) return -1;
return n / m + (n % m == 0 ? 0 : 1);
}
//int main()
//{
// ios_base::sync_with_stdio(0); istream::sync_with_stdio(0); cin.tie(0); cout.tie(0);
//
//
//}
# | 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... |