답안 #396179

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
396179 2021-04-29T14:09:47 Z Berted Type Printer (IOI08_printer) C++14
100 / 100
148 ms 51684 KB
#include <iostream>

using namespace std;

const int INF = 1e8;

int N; string ans;
int adj[500001][26], cnt[500001], DP[500001], sz = 0;

inline int newNode()
{
	for (int i = 0; i < 26; i++) adj[sz][i] = -1;
	return sz++;
}

inline void insert(int u, int i, const string& s)
{
	if (i < s.size())
	{
		int &v = adj[u][s[i] - 'a'];
		if (v == -1) {v = newNode();}
		insert(v, i + 1, s); DP[u] = max(DP[u], DP[v] + 1);
	}
	else {cnt[u]++;}
}

inline void solve(int u, bool m)
{
	int hvy = -1;
	for (int i = 0; i < cnt[u]; i++) ans.push_back('P');
	for (int i = 0; i < 26; i++)
	{
		if (adj[u][i] != -1 && m && (hvy == -1 || DP[adj[u][i]] > DP[adj[u][hvy]])) hvy = i;
	}
	for (int i = 0; i < 26; i++)
	{
		if (adj[u][i] != -1 && hvy != i) 
		{
			ans.push_back(i + 'a');
			solve(adj[u][i], 0);
			ans.push_back('-');
		}
	}
	if (hvy != -1) {ans.push_back(hvy + 'a'); solve(adj[u][hvy], 1);}
}

int main()
{
	ios :: sync_with_stdio(0); cin.tie(0); cout.tie(0);
	cin >> N;
	newNode();
	for (int i = 0; i < N; i++) {string S; cin >> S; insert(0, 0, S);}
	solve(0, 1);
	cout << ans.size() << "\n";
	for (const char &c : ans) cout << c << "\n";
	return 0;
}

Compilation message

printer.cpp: In function 'void insert(int, int, const string&)':
printer.cpp:18:8: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   18 |  if (i < s.size())
      |      ~~^~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 332 KB Output is correct
2 Correct 1 ms 332 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 332 KB Output is correct
2 Correct 1 ms 332 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 332 KB Output is correct
2 Correct 1 ms 332 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 332 KB Output is correct
2 Correct 1 ms 332 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 332 KB Output is correct
2 Correct 2 ms 768 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 1100 KB Output is correct
2 Correct 4 ms 1356 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 9 ms 3284 KB Output is correct
2 Correct 19 ms 6732 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 24 ms 7772 KB Output is correct
2 Correct 9 ms 1996 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 56 ms 18864 KB Output is correct
2 Correct 134 ms 43128 KB Output is correct
3 Correct 67 ms 22212 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 47 ms 14872 KB Output is correct
2 Correct 148 ms 51684 KB Output is correct
3 Correct 75 ms 25696 KB Output is correct
4 Correct 131 ms 48660 KB Output is correct