Submission #4538631
Source Code Expand
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <random>
#include <numeric>
#include <queue>
#include <map>
#include <list>
#include <vector>
#include <string>
#include <stack>
#include <limits>
#include <climits>
#include <cassert>
#include <fstream>
#include <cstring>
#include <cmath>
#include <bitset>
#include <iomanip>
#include <algorithm>
#include <functional>
#include <cstdio>
#include <ciso646>
#include <set>
#include <array>
#include <unordered_map>
#include <unordered_set>
#include <type_traits>
using namespace std;
#define FOR(i, a, b) for (int i = (a); i < (b); i++)
#define RFOR(i, a, b) for (int i = (b)-1; i >= (a); i--)
#define REP(i, n) for (int i = 0; i < (n); i++)
#define RREP(i, n) for (int i = (n)-1; i >= 0; i--)
#define inf 0x3f3f3f3f3f3f3f3f
#define ALL(a) (a).begin(), (a).end()
#define DEBUG(x) // cerr<<#x<<": "<<x<<endl
#define ll long long
#define ull unsigned long long
using pii = pair<ll, ll>;
#define eps 1e-14
#define SETUP cin.tie(0), ios::sync_with_stdio(false), cout << setprecision(15) << std::fixed;
#define chmin(x,y) x=min(x,y)
#define chmax(x,y) x=max(x,y)
template <class T>
using vec2 = std::vector<vector<T>>;
namespace
{
struct input_returnner
{
ll N;
input_returnner(ll N_ = 0) : N(N_) {}
template <typename T>
operator vector<T>() const
{
vector<T> res(N);
for (auto &a : res)
cin >> a;
return std::move(res);
}
template <typename T>
operator T() const
{
T res;
cin >> res;
return res;
}
template <typename T>
T operator-(T right) { return T(input_returnner()) - right; }
template <typename T>
T operator+(T right) { return T(input_returnner()) + right; }
template <typename T>
T operator*(T right) { return T(input_returnner()) * right; }
template <typename T>
T operator/(T right) { return T(input_returnner()) / right; }
template <typename T>
T operator<<(T right) { return T(input_returnner()) << right; }
template <typename T>
T operator>>(T right) { return T(input_returnner()) >> right; }
};
template <typename T>
input_returnner in() { return in<T>(); }
input_returnner in() { return input_returnner(); }
input_returnner in(ll N) { return std::move(input_returnner(N)); }
} // namespace
template <typename T>
istream &operator>>(istream &is, vector<T> &vec)
{
for (T &x : vec)
is >> x;
return is;
}
template <typename T>
struct is_vector : std::false_type
{
};
template <typename T>
struct is_vector<std::vector<T>> : std::true_type
{
};
template <typename T>
constexpr bool is_vector_v = is_vector<T>::value;
template <typename T>
std::ostream &operator<<(std::ostream &out, const std::vector<T> &v)
{
if (!v.empty())
{
for (int i = 0; i < v.size(); ++i)
{
out << v[i] << (i == v.size() - 1 ? "\n" : (is_vector_v<T> ? "" : ", "));
}
}
return out;
}
namespace std
{
// ref: https://stackoverflow.com/questions/7110301/generic-hash-for-tuples-in-unordered-map-unordered-set
template <class T>
inline void hash_combine(std::size_t &seed, T const &v)
{
seed ^= std::hash<T>()(v) + 0x9e3779b9 + (seed << 6) + (seed >> 2);
}
// Recursive template code derived from Matthieu M.
template <class Tuple, size_t Index = std::tuple_size<Tuple>::value - 1>
struct HashValueImpl
{
static void apply(size_t &seed, Tuple const &tuple)
{
HashValueImpl<Tuple, Index - 1>::apply(seed, tuple);
hash_combine(seed, std::get<Index>(tuple));
}
};
template <class Tuple>
struct HashValueImpl<Tuple, 0>
{
static void apply(size_t &seed, Tuple const &tuple)
{
hash_combine(seed, std::get<0>(tuple));
}
};
template <typename... TT>
struct hash<std::tuple<TT...>>
{
size_t operator()(std::tuple<TT...> const &tt) const
{
size_t seed = 0;
HashValueImpl<std::tuple<TT...>>::apply(seed, tt);
return seed;
}
};
template <class T, class U>
class hash<std::pair<T, U>>
{
public:
size_t operator()(const std::pair<T, U> &x) const
{
return hash<std::tuple<T, U>>()(std::tie(x.first, x.second));
}
};
} // namespace std
// ref: https://stackoverflow.com/questions/6245735/pretty-print-stdtuple
namespace aux
{
template <std::size_t...>
struct seq
{
};
template <std::size_t N, std::size_t... Is>
struct gen_seq : gen_seq<N - 1, N - 1, Is...>
{
};
template <std::size_t... Is>
struct gen_seq<0, Is...> : seq<Is...>
{
};
template <class Ch, class Tr, class Tuple, std::size_t... Is>
void print_tuple(std::basic_ostream<Ch, Tr> &os, Tuple const &t, seq<Is...>)
{
using swallow = int[];
(void)swallow {
0, (void(os << (Is == 0 ? "" : ", ") << std::get<Is>(t)), 0)...
};
}
} // namespace aux
template <class Ch, class Tr, class... Args>
auto operator<<(std::basic_ostream<Ch, Tr> &os, std::tuple<Args...> const &t)
-> std::basic_ostream<Ch, Tr> &
{
os << "(";
aux::print_tuple(os, t, aux::gen_seq<sizeof...(Args)>());
return os << ")";
}
template <class S, class T>
std::ostream &operator<<(std::ostream &os, const std::pair<S, T> &p)
{
return os << "(" << p.first << ", " << p.second << ")";
}
// ref: https://stackoverflow.com/questions/8542591/c11-reverse-range-based-for-loo�Fp
template <typename T>
struct reversion_wrapper
{
T &iterable;
};
template <typename T>
auto begin(reversion_wrapper<T> w) { return std::rbegin(w.iterable); }
template <typename T>
auto end(reversion_wrapper<T> w) { return std::rend(w.iterable); }
template <typename T>
reversion_wrapper<T> REV(T &&iterable) { return { iterable }; }
template <class T>
bool inside(T left, T val, T right)
{
return left <= val and val < right;
}
template <class T>
T bitCount(T num)
{
T res = 0;
while (num > 0)
{
if (num & 1)
++res;
num >>= 1;
}
return res;
}
ll MOD = 1e9 + 7;
void solve();
signed main()
{
SETUP;
#ifdef _DEBUG
while (true)
{
#endif
solve();
#ifdef _DEBUG
cout << "-------" << endl;
}
#endif
#ifdef _DEBUG
system("pause");
#endif
return 0;
}
#define int ll
// template
void solve() {
int N, M; cin >> N >> M;
vector<int> A(M);
for (auto &a : A) cin >> a;
vector<vector<int>> cnt(N, vector<int>(M, 0));
vector<vector<int> > num_index(N);
REP(i, A.size()) {
cnt[A[i]][i] = 1;
num_index[A[i]].push_back(i);
}
REP(i, cnt.size()) {
FOR(j, 1, cnt[i].size()) {
cnt[i][j] += cnt[i][j - 1];
}
}
vector<int> res;
res.push_back(0);
int ans = 0;
FOR(tar, 1, N) {
// resのposの位置に挿入
pii mi{ inf, -1 };
REP(pos, res.size() + 1) {
vector<int> left_element;
vector<int> right_element;
REP(i, pos) {
left_element.push_back(res[i]);
}
FOR(i, pos, res.size()) {
right_element.push_back(res[i]);
}
int count = 0;
for (auto &a : num_index[tar]) {
for (auto &le : left_element) {
if (a - 1 >= 0) {
count += cnt[le][a - 1];
}
}
for (auto &re : right_element) {
count += cnt[re].back() - cnt[re][a];
}
}
if (mi.first > count) {
mi = { count, pos };
}
}
if (mi.second == res.size()) {
res.push_back(tar);
}
else {
auto it = res.begin();
res.insert(it + mi.second, tar);
}
ans += mi.first;
}
cout << ans << endl;
}
Submission Info
| Submission Time |
|
| Task |
G - Teishoku |
| User |
team_kosanaif |
| Language |
C++14 (GCC 5.4.1) |
| Score |
200 |
| Code Size |
7442 Byte |
| Status |
AC |
| Exec Time |
104 ms |
| Memory |
28772 KiB |
Judge Result
| Set Name |
All |
| Score / Max Score |
200 / 200 |
| Status |
|
| Set Name |
Test Cases |
| All |
0-sample, 0-sample0, 0-sample1, 1-random-small-0, 1-random-small-1, 1-random-small-2, 1-random-small-3, 1-random-small-4, 1-random-small-5, 1-random-small-6, 1-random-small-7, 1-random-small-8, 1-random-small-9, 2-random-large-0, 2-random-large-1, 2-random-large-2, 2-random-large-3, 2-random-large-4, 2-random-large-5, 2-random-large-6, 2-random-large-7, 2-random-large-8, 2-random-large-9, 3-random-large2-0, 3-random-large2-1, 3-random-large2-2, 3-random-large2-3, 3-random-large2-4, 3-random-large2-5, 3-random-large2-6, 3-random-large2-7, 3-random-large2-8, 3-random-large2-9, 3-special-1, 3-special-2, 3-special-3, 3-special-4, 9-hand-small0 |
| Case Name |
Status |
Exec Time |
Memory |
| 0-sample |
AC |
1 ms |
256 KiB |
| 0-sample0 |
AC |
1 ms |
256 KiB |
| 0-sample1 |
AC |
1 ms |
256 KiB |
| 1-random-small-0 |
AC |
1 ms |
256 KiB |
| 1-random-small-1 |
AC |
1 ms |
256 KiB |
| 1-random-small-2 |
AC |
1 ms |
256 KiB |
| 1-random-small-3 |
AC |
1 ms |
256 KiB |
| 1-random-small-4 |
AC |
1 ms |
256 KiB |
| 1-random-small-5 |
AC |
1 ms |
256 KiB |
| 1-random-small-6 |
AC |
1 ms |
256 KiB |
| 1-random-small-7 |
AC |
1 ms |
256 KiB |
| 1-random-small-8 |
AC |
1 ms |
256 KiB |
| 1-random-small-9 |
AC |
1 ms |
256 KiB |
| 2-random-large-0 |
AC |
14 ms |
5188 KiB |
| 2-random-large-1 |
AC |
53 ms |
20240 KiB |
| 2-random-large-2 |
AC |
19 ms |
8836 KiB |
| 2-random-large-3 |
AC |
3 ms |
1280 KiB |
| 2-random-large-4 |
AC |
7 ms |
2448 KiB |
| 2-random-large-5 |
AC |
35 ms |
14036 KiB |
| 2-random-large-6 |
AC |
22 ms |
9680 KiB |
| 2-random-large-7 |
AC |
15 ms |
5960 KiB |
| 2-random-large-8 |
AC |
24 ms |
10912 KiB |
| 2-random-large-9 |
AC |
7 ms |
2880 KiB |
| 3-random-large2-0 |
AC |
89 ms |
27236 KiB |
| 3-random-large2-1 |
AC |
89 ms |
27364 KiB |
| 3-random-large2-2 |
AC |
89 ms |
27236 KiB |
| 3-random-large2-3 |
AC |
89 ms |
27364 KiB |
| 3-random-large2-4 |
AC |
90 ms |
27364 KiB |
| 3-random-large2-5 |
AC |
89 ms |
27364 KiB |
| 3-random-large2-6 |
AC |
89 ms |
27364 KiB |
| 3-random-large2-7 |
AC |
90 ms |
27364 KiB |
| 3-random-large2-8 |
AC |
89 ms |
27364 KiB |
| 3-random-large2-9 |
AC |
89 ms |
27364 KiB |
| 3-special-1 |
AC |
20 ms |
7908 KiB |
| 3-special-2 |
AC |
19 ms |
7908 KiB |
| 3-special-3 |
AC |
102 ms |
27364 KiB |
| 3-special-4 |
AC |
104 ms |
28772 KiB |
| 9-hand-small0 |
AC |
1 ms |
256 KiB |