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
AC × 38
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