mirror of
https://git.sb/baoshuo/OI-codes.git
synced 2024-11-23 14:08:46 +00:00
parent
6b572e15fa
commit
866d42f1b3
81
LibreOJ/3994/3994.cpp
Normal file
81
LibreOJ/3994/3994.cpp
Normal file
@ -0,0 +1,81 @@
|
||||
#include <iostream>
|
||||
#include <array>
|
||||
#include <fstream>
|
||||
#include <set>
|
||||
|
||||
// using std::cin;
|
||||
// using std::cout;
|
||||
std::ifstream cin("lock.in");
|
||||
std::ofstream cout("lock.out");
|
||||
const char endl = '\n';
|
||||
|
||||
const int N = 10,
|
||||
M = 5;
|
||||
|
||||
int n, ans;
|
||||
std::array<int, M> a[N];
|
||||
std::set<std::array<int, M>> set_pre;
|
||||
|
||||
int main() {
|
||||
std::ios::sync_with_stdio(false);
|
||||
cin.tie(nullptr);
|
||||
|
||||
cin >> n;
|
||||
|
||||
for (int i = 1; i <= n; i++) {
|
||||
for (int j = 0; j < M; j++) {
|
||||
cin >> a[i][j];
|
||||
}
|
||||
}
|
||||
|
||||
for (int i = 1; i <= n; i++) {
|
||||
std::set<std::array<int, M>> set_now;
|
||||
|
||||
// Type 1: Only one element is different.
|
||||
for (int j = 0; j < M; j++) {
|
||||
std::array<int, M> t = a[i];
|
||||
|
||||
for (int k = 0; k < 10; k++) {
|
||||
t[j] = (a[i][j] + k) % 10;
|
||||
|
||||
if (t[j] != a[i][j]) {
|
||||
set_now.emplace(t);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Type 2: Two adjacent elements are different.
|
||||
for (int j = 0; j + 1 < M; j++) {
|
||||
std::array<int, M> t = a[i];
|
||||
|
||||
for (int k = 0; k < 10; k++) {
|
||||
t[j] = (a[i][j] + k) % 10;
|
||||
t[j + 1] = (a[i][j + 1] + k) % 10;
|
||||
|
||||
if (t[j] != a[i][j]) {
|
||||
set_now.emplace(t);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (i == 1) {
|
||||
ans = set_now.size();
|
||||
set_pre = set_now;
|
||||
} else {
|
||||
std::set<std::array<int, M>> set;
|
||||
|
||||
for (auto o : set_pre) {
|
||||
if (set_now.count(o)) {
|
||||
set.emplace(o);
|
||||
}
|
||||
}
|
||||
|
||||
ans = set.size();
|
||||
set_pre = set;
|
||||
}
|
||||
}
|
||||
|
||||
cout << ans << endl;
|
||||
|
||||
return 0;
|
||||
}
|
BIN
LibreOJ/3994/data/lock1.ans
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock1.ans
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock1.in
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock1.in
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock10.ans
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock10.ans
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock10.in
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock10.in
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock2.ans
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock2.ans
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock2.in
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock2.in
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock3.ans
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock3.ans
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock3.in
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock3.in
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock4.ans
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock4.ans
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock4.in
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock4.in
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock5.ans
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock5.ans
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock5.in
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock5.in
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock6.ans
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock6.ans
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock6.in
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock6.in
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock7.ans
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock7.ans
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock7.in
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock7.in
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock8.ans
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock8.ans
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock8.in
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock8.in
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock9.ans
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock9.ans
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/data/lock9.in
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/data/lock9.in
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/samples/lock1.ans
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/samples/lock1.ans
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/samples/lock1.in
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/samples/lock1.in
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/samples/lock2.ans
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/samples/lock2.ans
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
LibreOJ/3994/samples/lock2.in
(Stored with Git LFS)
Normal file
BIN
LibreOJ/3994/samples/lock2.in
(Stored with Git LFS)
Normal file
Binary file not shown.
Loading…
Reference in New Issue
Block a user