답안 #384745

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
384745 2021-04-02T07:08:46 Z hivakarami Type Printer (IOI08_printer) C++14
80 / 100
814 ms 262148 KB
#include<bits/stdc++.h>
 
using namespace std;
 
typedef long long int ll;
typedef long double ld;
#define f first
#define s second
 
const int N = 2e5 + 100;
const ll mod = 998244353;
const ll inf = 1e9 + 10;

int node = 1;
bool mark[N], last[N];
deque<char> ans;
vector<pair<int, int>> adj[N];
int h[N], c[N][30], par[N];


void dfs(int u)
{
	if(mark[u])
		ans.push_back('P');
		
	int x2 = -1, t2 = -1;	
	for(auto it : adj[u])
	{
		int x = it.f, t = it.s;
		if(last[x])
		{
			x2 = x;
			t2 = t;
			continue;
		}
		
		ans.push_back(char(t+'a'));
		dfs(x);
	}
	
	if(x2 != -1)
	{
		ans.push_back(char(t2+'a'));
		dfs(x2);
	}
	
	ans.push_back('-');
	
}



void add(int u, string s)
{
	if(h[u] == s.size())
	{
		mark[u] = true;
		return;
	}
	
	int t = s[h[u]]-'a';
	
	if(c[u][t] == 0)
	{
		c[u][t] = node;
		adj[u].push_back({node, t});
		h[node] = h[u] + 1;
		par[node] = u;
		node++;
	}
	add(c[u][t], s);
}


 
int main()
{
    ios_base::sync_with_stdio(false), cin.tie(0), cout.tie(0);	
	
	int n;
	cin >> n;
	for(int i = 0; i < n; i++)
	{
		string s;
		cin >> s;
		add(0, s);
	}
	
	int mx = 0;
	for(int i = 0; i < node; i++)
	{
		if(h[i] > h[mx])
			mx = i;
	}
	
	while(mx != 0)
	{
		last[mx] = true;
		mx = par[mx];
	}
	
	dfs(0);
	
	
	while(ans.size() && ans.back() == '-')
		ans.pop_back();
	
	cout << ans.size() << endl;
	for(auto t : ans)
		cout << t << endl;
	
	
		
	return 0;
}
 
/*
3
print
the
poem
*/

 

Compilation message

printer.cpp: In function 'void add(int, std::string)':
printer.cpp:55:10: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   55 |  if(h[u] == s.size())
      |     ~~~~~^~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 5248 KB Output is correct
2 Correct 4 ms 5100 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 5100 KB Output is correct
2 Correct 4 ms 5100 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 5100 KB Output is correct
2 Correct 4 ms 5228 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 5100 KB Output is correct
2 Correct 4 ms 5100 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 7 ms 5100 KB Output is correct
2 Correct 24 ms 5612 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 35 ms 6124 KB Output is correct
2 Correct 44 ms 6380 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 122 ms 9196 KB Output is correct
2 Correct 254 ms 13804 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 305 ms 15340 KB Output is correct
2 Correct 103 ms 7276 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 814 ms 31128 KB Output is correct
2 Runtime error 244 ms 262148 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 631 ms 25248 KB Output is correct
2 Runtime error 119 ms 74004 KB Execution killed with signal 11
3 Halted 0 ms 0 KB -