#include <algorithm>
#include <iostream>
#include <vector>
#include <string>
#include <cmath>
using namespace std;
using llong = long long;
int ans = 100500;
int a[5][5];
int n, m;
inline int Val_(const vector<int>& col, const vector<int>& row, bool rows)
{
static int b[5][5];
for (int i = 0; i < n; ++i)
for (int j = 0; j < m; ++j)
b[i][j] = a[i][j];
int res = 0;
for (int j = 0; j < m; ++j)
{
res += min(col[j], n - col[j]);
vector<int> cur(n);
for (int i = 0; i < n; ++i) cur[i] = b[i][j];
rotate(cur.begin(), cur.begin() + col[j], cur.end());
for (int i = 0; i < n; ++i) b[i][j] = cur[i];
}
for (int i = 0; i < row.size(); ++i)
{
res += min(row[i], m - row[i]);
vector<int> cur(m);
for (int j = 0; j < m; ++j) cur[j] = b[i][j];
rotate(cur.begin(), cur.begin() + row[i], cur.end());
for (int j = 0; j < m; ++j) b[i][j] = cur[j];
}
bool ans1 = true, ans2 = true;
for (int i = 0; i < row.size(); ++i)
for (int j = 0; j < m; ++j)
{
if (b[i][j] != b[i][0])
ans1 = false;
if (b[i][j] != b[0][j])
ans2 = false;
}
bool ans = (rows ? ans1 : ans2);
if (!ans)
return 100500;
return res;
}
inline int Val(const vector<int>& col, const vector<int>& row)
{
if (col[0] == 0 && col[1] == 0 && col[2] == 0 && row[0] == 0)
cerr << "";
static int b[5][5];
for (int i = 0; i < n; ++i)
for (int j = 0; j < m; ++j)
b[i][j] = a[i][j];
int res = 0;
for (int j = 0; j < m; ++j)
{
res += min(col[j], n - col[j]);
vector<int> cur(n);
for (int i = 0; i < n; ++i) cur[i] = b[i][j];
rotate(cur.begin(), cur.begin() + col[j], cur.end());
for (int i = 0; i < n; ++i) b[i][j] = cur[i];
}
for (int i = 0; i < row.size(); ++i)
{
res += min(row[i], m - row[i]);
vector<int> cur(m);
for (int j = 0; j < m; ++j) cur[j] = b[i][j];
rotate(cur.begin(), cur.begin() + row[i], cur.end());
for (int j = 0; j < m; ++j) b[i][j] = cur[j];
}
for (int i = 1; i < n; ++i)
{
int ires = 100500;
for (int c = 0; c < m; ++c)
{
int curres = min(c, m - c);
vector<int> cur(m);
for (int j = 0; j < m; ++j) cur[j] = b[i][j];
rotate(cur.begin(), cur.begin() + c, cur.end());
bool curans = true;
for (int j = 0; j < m; ++j)
if (cur[j] != b[0][j])
{
curans = false;
break;
}
if (curans)
ires = min(ires, curres);
}
res += ires;
}
if (res == 0)
cerr << "";
return res;
}
void Solve(vector<int>& col, vector<int>& row)
{
if (col.size() == m && row.size() == 0)
{
row.resize(n);
ans = min(ans, Val_(col, row, true));
row.clear();
}
if (col.size() == m && row.size() == /*n*/1)
{
ans = min(ans, Val(col, row));
return;
}
if (col.size() == m)
{
row.push_back(0);
for (row.back() = 0; row.back() < m; ++row.back())
Solve(col, row);
row.pop_back();
}
else
{
col.push_back(0);
for (col.back() = 0; col.back() < n; ++col.back())
Solve(col, row);
col.pop_back();
}
}
int main()
{
ios::sync_with_stdio(0);
cin.tie(0); cout.tie(0);
cin >> n >> m;
for (int i = 0; i < n; ++i)
for (int j = 0; j < m; ++j)
cin >> a[i][j];
vector<int> col, row;
Solve(col, row);
cout << ans;
}
Compilation message
riddicks.cpp: In function 'int Val_(const std::vector<int>&, const std::vector<int>&, bool)':
riddicks.cpp:28:23: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for (int i = 0; i < row.size(); ++i)
~~^~~~~~~~~~~~
riddicks.cpp:37:23: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for (int i = 0; i < row.size(); ++i)
~~^~~~~~~~~~~~
riddicks.cpp: In function 'int Val(const std::vector<int>&, const std::vector<int>&)':
riddicks.cpp:67:23: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for (int i = 0; i < row.size(); ++i)
~~^~~~~~~~~~~~
riddicks.cpp: In function 'void Solve(std::vector<int>&, std::vector<int>&)':
riddicks.cpp:102:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
if (col.size() == m && row.size() == 0)
~~~~~~~~~~~^~~~
riddicks.cpp:108:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
if (col.size() == m && row.size() == /*n*/1)
~~~~~~~~~~~^~~~
riddicks.cpp:113:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
if (col.size() == m)
~~~~~~~~~~~^~~~
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
5 ms |
384 KB |
Output is correct |
2 |
Correct |
4 ms |
384 KB |
Output is correct |
3 |
Correct |
4 ms |
384 KB |
Output is correct |
4 |
Correct |
5 ms |
384 KB |
Output is correct |
5 |
Correct |
4 ms |
384 KB |
Output is correct |
6 |
Correct |
5 ms |
384 KB |
Output is correct |
7 |
Correct |
5 ms |
384 KB |
Output is correct |
8 |
Correct |
6 ms |
384 KB |
Output is correct |
9 |
Correct |
12 ms |
384 KB |
Output is correct |
10 |
Correct |
8 ms |
384 KB |
Output is correct |
11 |
Correct |
12 ms |
384 KB |
Output is correct |
12 |
Correct |
8 ms |
384 KB |
Output is correct |
13 |
Correct |
32 ms |
384 KB |
Output is correct |
14 |
Correct |
32 ms |
384 KB |
Output is correct |
15 |
Correct |
34 ms |
384 KB |
Output is correct |
16 |
Correct |
32 ms |
384 KB |
Output is correct |
17 |
Correct |
36 ms |
504 KB |
Output is correct |
18 |
Correct |
32 ms |
392 KB |
Output is correct |
19 |
Correct |
33 ms |
384 KB |
Output is correct |
20 |
Correct |
32 ms |
384 KB |
Output is correct |