# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
739604 | MODDI | Type Printer (IOI08_printer) | C++14 | 52 ms | 2236 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
#define pb push_back
#define mp make_pair
typedef long long ll;
typedef pair<long long, long long> pll;
typedef pair<int,int> pii;
typedef vector<long long> vl;
typedef vector<int> vi;
int n;
vector<string> str;
bool lower(string a, string b){
for(int i = 0; i < a.size(); i++){
if(a[i] < b[i]) return true;
else if(b[i] < a[i]) return false;
}
return true;
}
bool comp(string& a, string& b){
if(a.size() < b.size()) return true;
else if(b.size() < a.size()) return false;
else{
return lower(a, b);
}
}
int main(){
cin>>n;
str.resize(n);
for(int i = 0; i < n; i++)
cin>>str[i];
sort(str.begin(), str.end(), comp);
string printer;
vector<char> moves;
for(int i = 0; i < str.size(); i++){
while(printer.size() > str[i].size())
{
moves.pb('-');
printer.pop_back();
}
int first = 0;
while(first < str[i].size() && printer[first] == str[i][first]) first++;
// assert(false);
while(printer.size() > first)
{
printer.pop_back();
moves.pb('-');
}
// assert(false);
while(printer != str[i]){
printer.pb(str[i][first]);
moves.pb(str[i][first]);
first++;
}
moves.pb('P');
}
cout<<moves.size()<<endl;
for(auto t : moves)
cout<<t<<'\n';
return 0;
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |