| Task: | Merkkijono |
| Sender: | Ilmari2000 |
| Submission time: | 2018-01-18 17:09:45 +0200 |
| Language: | C++ |
| Status: | READY |
| Result: | 100 |
| group | verdict | score |
|---|---|---|
| #1 | ACCEPTED | 100 |
| test | verdict | time | |
|---|---|---|---|
| #1 | ACCEPTED | 0.04 s | details |
| #2 | ACCEPTED | 0.04 s | details |
| #3 | ACCEPTED | 0.05 s | details |
| #4 | ACCEPTED | 0.04 s | details |
| #5 | ACCEPTED | 0.04 s | details |
Compiler report
input/code.cpp: In function 'int main()':
input/code.cpp:26:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i = 0; i < str.size(); i++)
^
input/code.cpp:48:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i = 0; i < coms.size(); i++)
^Code
#include <iostream>
#include <vector>
using namespace std;
int main()
{
string str;
cin >> str;
vector<int> coms;
bool loop = true;
char cor = 'Z';
while(loop)
{
if(str[0] > str[1] && str[0] < cor)
{
swap(str[0], str[1]);
coms.push_back(1);
}
loop = false;
for(int i = 0; i < str.size(); i++)
{
if(str[i] == cor)
{
while((int)str[i - 1] == (int)cor - 1 && i >= 0) {i--; cor--;}
if(cor != 'A')
loop = true;
break;
}
}
if(loop)
{
str = str[str.size() - 1] + str;
str.erase(str.begin() + str.size() - 1);
coms.push_back(2);
}
}
cout << coms.size() << endl;
for(int i = 0; i < coms.size(); i++)
{
cout << (coms[i] == 1 ? "SWAP" : "MOVE") << endl;
}
}
Test details
Test 1
Verdict: ACCEPTED
| input |
|---|
| ABCDEFGHIJKLMNOPQRSTUVWXYZ |
| correct output |
|---|
| 0 |
| user output |
|---|
| 0 |
Test 2
Verdict: ACCEPTED
| input |
|---|
| ZYXWVUTSRQPONMLKJIHGFEDCBA |
| correct output |
|---|
| 923 MOVE MOVE SWAP MOVE ... |
| user output |
|---|
| 923 MOVE MOVE SWAP MOVE ... |
Test 3
Verdict: ACCEPTED
| input |
|---|
| RPJMFWBHYQOTXUAENLDGZISCVK |
| correct output |
|---|
| 611 SWAP MOVE MOVE SWAP ... |
| user output |
|---|
| 611 SWAP MOVE MOVE SWAP ... |
Test 4
Verdict: ACCEPTED
| input |
|---|
| GWJSPBHANMXYFLKIDORVUCEZQT |
| correct output |
|---|
| 659 MOVE SWAP MOVE SWAP ... |
| user output |
|---|
| 659 MOVE SWAP MOVE SWAP ... |
Test 5
Verdict: ACCEPTED
| input |
|---|
| BJYNFLKEIUCZMQHRAXOGWPSDTV |
| correct output |
|---|
| 624 MOVE SWAP MOVE SWAP ... |
| user output |
|---|
| 624 MOVE SWAP MOVE SWAP ... |
