답안 #958696

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
958696 2024-04-06T11:30:34 Z shenfe1 바이러스 (JOI19_virus) C++17
20 / 100
488 ms 262144 KB
// #pragma GCC target("avx2")
// #pragma GCC optimize("O3")
// #include <x86intrin.h>
 
#include <bits/stdc++.h>
#include <chrono>
#include <random>
 
// @author: Vlapos
 
namespace operators
{
	template <typename T1, typename T2>
	std::istream &operator>>(std::istream &in, std::pair<T1, T2> &x)
	{
		in >> x.first >> x.second;
		return in;
	}
 
	template <typename T1, typename T2>
	std::ostream &operator<<(std::ostream &out, std::pair<T1, T2> x)
	{
		out << x.first << " " << x.second;
		return out;
	}
 
	template <typename T1>
	std::istream &operator>>(std::istream &in, std::vector<T1> &x)
	{
		for (auto &i : x)
			in >> i;
		return in;
	}
 
	template <typename T1>
	std::ostream &operator<<(std::ostream &out, std::vector<T1> &x)
	{
		for (auto &i : x)
			out << i << " ";
		return out;
	}
 
	template <typename T1>
	std::ostream &operator<<(std::ostream &out, std::set<T1> &x)
	{
		for (auto &i : x)
			out << i << " ";
		return out;
	}
}
 
// name spaces
using namespace std;
using namespace operators;
// end of name spaces
 
// defines
#define ll long long
#define ull unsigned long long
#define pb push_back
#define mp make_pair
#define pii pair<int, int>
#define pll pair<ll, ll>
#define f first
#define s second
#define uint unsigned int
#define all(vc) vc.begin(), vc.end()
// end of defines
 
// usefull stuff
 
void boost()
{
	ios_base ::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
}
 
inline int getbit(int &x, int &bt) { return (x >> bt) & 1; }
 
const int dx4[4] = {-1, 0, 0, 1};
const int dy4[4] = {0, -1, 1, 0};
const int dx8[8] = {-1, -1, -1, 0, 0, 1, 1, 1};
const int dy8[8] = {-1, -0, 1, -1, 1, -1, 0, 1};
 
const ll INF = (1e18) + 500;
const int BIG = (1e9) + 100;
const int MAXN = (1e5) + 5;
const int MOD7 = (1e9) + 7;
const int MOD9 = (1e9) + 9;
const uint MODFFT = 998244353;
 
// #define int ll
 
const int maxN = 800 * 800+10;
// const int maxN = 810 * 810;
 
bool rules[maxN][16];
 
struct DSU
{
	map<int, bool> is[maxN];
	int pr[maxN];
 
	void init(int n)
	{
		for (int i = 0; i < n; ++i)
		{
			pr[i] = i;
			is[i][i];
		}
	}
 
	int getRoot(int c)
	{
		return pr[c] == c ? c : pr[c] = getRoot(pr[c]);
	}
};
 
bool bad[maxN];

struct test
{
	int m, r, c;
  int HELP[maxN];
 
	bool good(int x, int y)
	{
		return x >= 0 and y >= 0 and x < r and y < c;
	}
	vector<int> tin, fup;
	DSU dsu;
 
	int ans = BIG, cnt = 0;
	int timer = 0;
 
	bool dfs(int v)
	{
		tin[v] = fup[v] = ++timer;
		queue<int> toV;
		{
			for (int d = 0; d < 4; ++d)
			{
				int tox = (v / c) + dx4[d];
				int toy = (v % c) + dy4[d];
				if (good(tox, toy))
				{
					int mask = 0;
					for (int D = 0; D < 4; ++D)
					{
						int totox = tox + dx4[D];
						int totoy = toy + dy4[D];
						if (good(totox, totoy))
							if (dsu.is[v].find(totox * c + totoy) != dsu.is[v].end())
								mask |= (1 << D);
					}
					if (rules[tox * c + toy][mask])
					{
						toV.push(tox * c + toy);
					}
				}
			}
		}
 
		while (toV.size())
		{
			int to = toV.front();
			to = dsu.getRoot(to);
			toV.pop();
			if (dsu.getRoot(to) == dsu.getRoot(v))
				continue;
			if (!tin[to])
			{
        dfs(to);
				bad[v] |= bad[to];
				fup[v] = min(fup[v], fup[to]);
				if (fup[to] <= tin[v])
				{
					// merge prev and cur
					if (dsu.is[v].size() < dsu.is[to].size())
						swap(dsu.is[v], dsu.is[to]);					
          for (auto &[el, bf] : dsu.is[to])
						dsu.is[v][el];
					dsu.pr[to] = v;
					for (auto &[el, bf] : dsu.is[to])
						for (int d = 0; d < 4; ++d)
						{
							int tox = (el / c) + dx4[d];
							int toy = (el % c) + dy4[d];
							if (good(tox, toy))
							{
								int mask = 0;
								for (int D = 0; D < 4; ++D)
								{
									int totox = tox + dx4[D];
									int totoy = toy + dy4[D];
									if (good(totox, totoy))
										if (dsu.is[v].count(totox * c + totoy))
										{
											mask += (1 << D);
										}
								}
								if (rules[tox * c + toy][mask] and dsu.getRoot(tox * c + toy) != dsu.getRoot(v) and !HELP[dsu.getRoot(tox * c + toy)])
								{
									int cur = dsu.getRoot(tox * c + toy);
									HELP[cur] = 1;
									toV.push(cur);
								}
							}
						}
          dsu.is[to].clear();
				}
				else
					bad[v] = 1;
			}
			else if (tin[v] > tin[to])
			{
				fup[v] = min(tin[to], fup[v]);
			}
			else
				bad[v] = 1;
		}
 
		if (tin[v] == fup[v] and !bad[v])
		{
			int VAL = (int)dsu.is[v].size();
			if (ans > VAL)
			{
				ans = VAL;
				cnt = VAL;
			}
			else if (ans == VAL)
			{
				cnt += VAL;
			}
		}
		tin[v] = BIG;
		return bad[v];
	}
 
	void solve(int testcase)
	{
		boost();
 
		cin >> m >> r >> c;
 
		dsu.init(r * c);
		tin.resize(r * c);
		fup.resize(r * c);
    memset(HELP,0,sizeof(HELP));
		string s;
		cin >> s;
		s = s + s;
		m *= 2;
 
		// const int dx4[4] = {-1, 0, 0, 1};
		// const int dy4[4] = {0, -1, 1, 0};
		map<char, int> dist;
		dist['N'] = 0;
		dist['W'] = 1;
		dist['E'] = 2;
		dist['S'] = 3;
 
		vector<int> longest(1 << 4);
		for (int i = 1; i < (1 << 4); ++i)
		{
			int cnt = 0, cur = 0;
			for (int j = 0; j < m; ++j)
			{
				if ((i >> (dist[s[j]])) & 1)
					cur++;
				else
					cur = 0;
				cnt = max(cnt, cur);
			}
			if (cnt == m)
				longest[i] = BIG;
			else
				longest[i] = cnt;
		}
 
		vector<vector<int>> u(r, vector<int>(c));
		cin >> u;
		for (int i = 0; i < r; ++i)
			for (int j = 0; j < c; ++j)
				if (!u[i][j])
					u[i][j] = BIG + 10;
 
		for (int i = 0; i < r; ++i)
			for (int j = 0; j < c; ++j)
				for (int mask = 0; mask < (1 << 4); ++mask)
				{
					bool cur = true;
					for (int val = 0; val < 4; ++val)
					{
						int tox = i + dx4[val];
						int toy = j + dy4[val];
						cur &= (good(tox, toy) or !((mask >> val) & 1));
					}
					if (cur and u[i][j] <= longest[mask])
					{
						rules[i * c + j][mask] = 1;
					}
				}
 
		for (int i = 0; i < r; ++i)
			for (int j = 0; j < c; ++j)
				if (!tin[i * c + j] and u[i][j] != BIG + 10)
					dfs(i * c + j);
		if (ans == BIG)
			ans = 0, cnt = 0;
 
		cout << ans << '\n'
			 << cnt << '\n';
	}
};
 
main()
{
	boost();
	int q = 1;
	// cin >> q;
	for (int i = 0; i < q; i++)
	{
		test t;
		t.solve(i);
	}
	return 0;
}
//[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]//
//                                                                                    //
//                               Coded by Der_Vlἀpos                                  //
//                                                                                    //
//[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[[]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]//

Compilation message

virus.cpp:318:1: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
  318 | main()
      | ^~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 28 ms 37712 KB Output is correct
2 Correct 283 ms 83788 KB Output is correct
3 Correct 292 ms 84520 KB Output is correct
4 Correct 227 ms 83644 KB Output is correct
5 Correct 241 ms 83648 KB Output is correct
6 Correct 22 ms 35512 KB Output is correct
7 Correct 488 ms 85032 KB Output is correct
8 Correct 137 ms 56448 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 23 ms 37364 KB Output is correct
2 Correct 35 ms 37724 KB Output is correct
3 Correct 71 ms 37884 KB Output is correct
4 Correct 33 ms 37884 KB Output is correct
5 Correct 60 ms 36028 KB Output is correct
6 Correct 68 ms 39924 KB Output is correct
7 Correct 22 ms 37460 KB Output is correct
8 Correct 65 ms 37856 KB Output is correct
9 Correct 25 ms 37724 KB Output is correct
10 Correct 38 ms 37656 KB Output is correct
11 Correct 23 ms 37724 KB Output is correct
12 Correct 27 ms 38644 KB Output is correct
13 Correct 55 ms 37872 KB Output is correct
14 Correct 53 ms 38036 KB Output is correct
15 Correct 59 ms 40072 KB Output is correct
16 Correct 54 ms 37872 KB Output is correct
17 Correct 42 ms 37724 KB Output is correct
18 Correct 26 ms 37724 KB Output is correct
19 Correct 60 ms 37788 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 28 ms 37712 KB Output is correct
2 Correct 283 ms 83788 KB Output is correct
3 Correct 292 ms 84520 KB Output is correct
4 Correct 227 ms 83644 KB Output is correct
5 Correct 241 ms 83648 KB Output is correct
6 Correct 22 ms 35512 KB Output is correct
7 Correct 488 ms 85032 KB Output is correct
8 Correct 137 ms 56448 KB Output is correct
9 Correct 23 ms 37364 KB Output is correct
10 Correct 35 ms 37724 KB Output is correct
11 Correct 71 ms 37884 KB Output is correct
12 Correct 33 ms 37884 KB Output is correct
13 Correct 60 ms 36028 KB Output is correct
14 Correct 68 ms 39924 KB Output is correct
15 Correct 22 ms 37460 KB Output is correct
16 Correct 65 ms 37856 KB Output is correct
17 Correct 25 ms 37724 KB Output is correct
18 Correct 38 ms 37656 KB Output is correct
19 Correct 23 ms 37724 KB Output is correct
20 Correct 27 ms 38644 KB Output is correct
21 Correct 55 ms 37872 KB Output is correct
22 Correct 53 ms 38036 KB Output is correct
23 Correct 59 ms 40072 KB Output is correct
24 Correct 54 ms 37872 KB Output is correct
25 Correct 42 ms 37724 KB Output is correct
26 Correct 26 ms 37724 KB Output is correct
27 Correct 60 ms 37788 KB Output is correct
28 Runtime error 316 ms 262144 KB Execution killed with signal 9
29 Halted 0 ms 0 KB -