CSES - KILO 2017 3/5 - Results
Submission details
Task:Fruit game
Sender:Viljamin opetuslapset
Submission time:2017-09-19 19:08:32 +0300
Language:Java
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.14 sdetails
#2ACCEPTED0.13 sdetails
#3ACCEPTED0.13 sdetails
#4ACCEPTED0.14 sdetails
#5ACCEPTED0.13 sdetails
#6ACCEPTED0.12 sdetails
#7ACCEPTED0.11 sdetails
#8ACCEPTED0.14 sdetails
#9ACCEPTED0.18 sdetails
#10ACCEPTED0.23 sdetails
#11ACCEPTED0.27 sdetails
#12ACCEPTED0.54 sdetails
#13ACCEPTED0.51 sdetails
#14ACCEPTED0.75 sdetails
#15ACCEPTED0.75 sdetails
#16ACCEPTED0.60 sdetails
#17ACCEPTED0.65 sdetails
#18ACCEPTED0.59 sdetails
#19ACCEPTED0.59 sdetails
#20ACCEPTED0.66 sdetails
#21ACCEPTED0.57 sdetails
#22ACCEPTED0.32 sdetails
#23ACCEPTED0.29 sdetails
#24ACCEPTED0.30 sdetails
#25ACCEPTED0.27 sdetails
#26ACCEPTED0.31 sdetails
#27ACCEPTED0.29 sdetails
#28ACCEPTED0.34 sdetails
#29ACCEPTED0.32 sdetails
#30ACCEPTED0.31 sdetails
#31ACCEPTED0.28 sdetails
#32ACCEPTED0.45 sdetails
#33ACCEPTED0.63 sdetails
#34ACCEPTED0.48 sdetails
#35ACCEPTED0.64 sdetails
#36ACCEPTED0.71 sdetails
#37ACCEPTED0.61 sdetails
#38ACCEPTED0.67 sdetails
#39ACCEPTED0.67 sdetails
#40ACCEPTED0.58 sdetails
#41ACCEPTED0.76 sdetails
#42ACCEPTED0.60 sdetails
#43ACCEPTED0.72 sdetails
#44ACCEPTED0.58 sdetails
#45ACCEPTED0.54 sdetails
#46ACCEPTED0.43 sdetails
#47ACCEPTED0.51 sdetails
#48ACCEPTED0.40 sdetails
#49ACCEPTED0.70 sdetails
#50ACCEPTED0.55 sdetails
#51ACCEPTED0.75 sdetails
#52ACCEPTED0.73 sdetails
#53ACCEPTED0.85 sdetails
#54ACCEPTED0.73 sdetails
#55ACCEPTED0.12 sdetails
#56ACCEPTED0.90 sdetails

Code

import java.util.ArrayDeque;
import java.util.Deque;
import java.util.LinkedList;
import java.util.List;
import java.util.PriorityQueue;
import java.util.Queue;
import java.util.Stack;

/**
 *
 * @author juliuuus
 */
public class Main {

    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) {
        IO io = new IO();

        int t = io.nextInt();
        String[] voittajat = new String[t];

        for (int i = 0; i < t; i++) {
            String peli = io.next();
            int banaanit = 0;
            int omenat = 0;
            int syodytomenat = 0;
            int syodytbanaanit = 0;
            Stack<Character> jono1 = new Stack<>();
            Stack<Character> jono2 = new Stack<>();

            String[] osat = peli.split("C");

//            if (peli.charAt(0) == peli.charAt(peli.length() - 1)) {
//                voittajat[i] = (peli.charAt(0) == 'A') ? "Maija" : "Uolevi";
////                System.out.println("mayhem");
//                continue;
//            }
            for (char j : osat[0].toCharArray()) {
                if (j == 'A') {
                    omenat++;
                }
                if (j == 'B') {
                    banaanit++;
                }
                jono1.add(j);
            }
            if (osat.length > 1) {
                char[] q = osat[1].toCharArray();
                for (int m = osat[1].length() - 1; m >= 0; m--) {
//                char jee = q[m];
                    if (q[m] == 'A') {
                        omenat++;
                    }
                    if (q[m] == 'B') {
                        banaanit++;
                    }

                    jono2.add(q[m]);
                }
            }

            Stack<Character> uolevinPino = (peli.charAt(0) == 'A') ? jono1 : jono2;

            Stack<Character> maijanPino = (peli.charAt(0) == 'A') ? jono2 : jono1;

//            System.out.println(maijanPino);
            int vuoro = 2;

            while (true) {

                if (vuoro % 2 == 0) {
//                    UOLEVIN VUORO
                    if (!uolevinPino.empty() && uolevinPino.peek() == 'A') {
                        uolevinPino.pop();
                        syodytomenat++;
                    } else if (!maijanPino.empty() && maijanPino.peek() == 'A') {
                        maijanPino.pop();
                        syodytomenat++;

                    }
                } else {
//                   MAIJAN VUORO
                    if (!maijanPino.empty() && maijanPino.peek() == 'B') {
                        maijanPino.pop();
                        syodytbanaanit++;
                    } else if (!uolevinPino.empty() && uolevinPino.peek() == 'B') {
                        uolevinPino.pop();
                        syodytbanaanit++;
                    }
                }

                if (syodytomenat == omenat) {
                    voittajat[i] = "Uolevi";
                    break;
                } else if (syodytbanaanit == banaanit) {
                    voittajat[i] = "Maija";
                    break;
                }
                vuoro++;

            }

        }
        for (int p = 0; p < t; p++) {
            io.println(voittajat[p]);
        }

        io.close();
    }

}

Test details

Test 1

Verdict: ACCEPTED

input
3
AAACBB
CABAB
BBBBCBA

correct output
Maija
Uolevi
Maija

user output
Maija
Uolevi
Maija

Test 2

Verdict: ACCEPTED

input
10
BCAA
ABABBCBBAAA
BAAABBABCAAA
BABAACA
...

correct output
Maija
Maija
Uolevi
Uolevi
Uolevi
...

user output
Maija
Maija
Uolevi
Uolevi
Uolevi
...

Test 3

Verdict: ACCEPTED

input
10
AACBBAABB
CAABBBABBB
AAABCBBBBBA
AACBBBBA
...

correct output
Uolevi
Uolevi
Maija
Maija
Uolevi
...

user output
Uolevi
Uolevi
Maija
Maija
Uolevi
...

Test 4

Verdict: ACCEPTED

input
10
BCAA
ABBAAABCAAB
BBBABABCABBA
ABACABB
...

correct output
Maija
Maija
Maija
Uolevi
Uolevi
...

user output
Maija
Maija
Maija
Uolevi
Uolevi
...

Test 5

Verdict: ACCEPTED

input
10
AABACBABB
BBBBBACBBA
ABBCBBABABB
BAABCBBA
...

correct output
Maija
Maija
Maija
Maija
Maija
...

user output
Maija
Maija
Maija
Maija
Maija
...

Test 6

Verdict: ACCEPTED

input
10
BBBCBABBAAABBABAAAABABBBBABABB...

correct output
Maija
Uolevi
Uolevi
Maija
Maija
...

user output
Maija
Uolevi
Uolevi
Maija
Maija
...

Test 7

Verdict: ACCEPTED

input
10
BBBBAABBBBBBBBABBBAABBBBBABBAA...

correct output
Maija
Uolevi
Uolevi
Uolevi
Uolevi
...

user output
Maija
Uolevi
Uolevi
Uolevi
Uolevi
...

Test 8

Verdict: ACCEPTED

input
10
BBBBBAABAAAABAAAABABABBAAABBAA...

correct output
Uolevi
Uolevi
Uolevi
Uolevi
Uolevi
...

user output
Uolevi
Uolevi
Uolevi
Uolevi
Uolevi
...

Test 9

Verdict: ACCEPTED

input
10
AABAAAAAAAAAABAAAABABBAAAAAABB...

correct output
Uolevi
Maija
Maija
Maija
Uolevi
...

user output
Uolevi
Maija
Maija
Maija
Uolevi
...

Test 10

Verdict: ACCEPTED

input
10
ABABBBABABABBAABABAAABBBABAABB...

correct output
Maija
Maija
Uolevi
Maija
Maija
...

user output
Maija
Maija
Uolevi
Maija
Maija
...

Test 11

Verdict: ACCEPTED

input
10
AABBBAAABBABAAAAAABBBBABBBBBBB...

correct output
Maija
Maija
Maija
Uolevi
Maija
...

user output
Maija
Maija
Maija
Uolevi
Maija
...

Test 12

Verdict: ACCEPTED

input
1
AABBBABABAABBBABBBABABABBAAABB...

correct output
Maija

user output
Maija

Test 13

Verdict: ACCEPTED

input
1
BABBAABABBABBAAAABBABBBBABBBAB...

correct output
Uolevi

user output
Uolevi

Test 14

Verdict: ACCEPTED

input
10
ABAAABBAABAABBAAABAABBABBABBAA...

correct output
Maija
Maija
Maija
Uolevi
Maija
...

user output
Maija
Maija
Maija
Uolevi
Maija
...

Test 15

Verdict: ACCEPTED

input
10
AAAAABABBBBABAAABAAAAABBBBBABB...

correct output
Maija
Uolevi
Maija
Uolevi
Uolevi
...

user output
Maija
Uolevi
Maija
Uolevi
Uolevi
...

Test 16

Verdict: ACCEPTED

input
100
BAAABBAAABAABBBBAAAAABAABABABA...

correct output
Uolevi
Uolevi
Uolevi
Maija
Maija
...

user output
Uolevi
Uolevi
Uolevi
Maija
Maija
...

Test 17

Verdict: ACCEPTED

input
100
ABABABBBBBAABBBBBAABABAAAAABBB...

correct output
Maija
Uolevi
Maija
Uolevi
Uolevi
...

user output
Maija
Uolevi
Maija
Uolevi
Uolevi
...

Test 18

Verdict: ACCEPTED

input
1000
ABABBABBBBBBBBBAAAAAABBBBABBAB...

correct output
Maija
Maija
Maija
Uolevi
Maija
...

user output
Maija
Maija
Maija
Uolevi
Maija
...

Test 19

Verdict: ACCEPTED

input
1000
BABBBAABBBBAABABAAABAAABBBBBBA...

correct output
Maija
Uolevi
Maija
Maija
Uolevi
...

user output
Maija
Uolevi
Maija
Maija
Uolevi
...

Test 20

Verdict: ACCEPTED

input
10000
BBABBABBABBCAA
AABBABAABBABBBAAAAABAAAAAAAAAB...

correct output
Uolevi
Maija
Uolevi
Maija
Maija
...

user output
Uolevi
Maija
Uolevi
Maija
Maija
...

Test 21

Verdict: ACCEPTED

input
10000
BABABBBBBBABBAAABBBBAABBAAABBB...

correct output
Uolevi
Uolevi
Uolevi
Maija
Uolevi
...

user output
Uolevi
Uolevi
Uolevi
Maija
Uolevi
...

Test 22

Verdict: ACCEPTED

input
10000
AAAAAACBBAABA
ACBAABBBBBAB
ABACBAAAABAA
BBBBABBABACB
...

correct output
Maija
Uolevi
Maija
Uolevi
Uolevi
...

user output
Maija
Uolevi
Maija
Uolevi
Uolevi
...

Test 23

Verdict: ACCEPTED

input
10000
BAAABABBBBCAB
BBABABAACBAB
ABABBABCB
BBABBAAABAACB
...

correct output
Uolevi
Uolevi
Maija
Uolevi
Uolevi
...

user output
Uolevi
Uolevi
Maija
Uolevi
Uolevi
...

Test 24

Verdict: ACCEPTED

input
10000
BABBBABABCAA
AABBBBBABBABC
AAABBBAABAC
AAABBAACAAA
...

correct output
Uolevi
Maija
Maija
Maija
Uolevi
...

user output
Uolevi
Maija
Maija
Maija
Uolevi
...

Test 25

Verdict: ACCEPTED

input
10000
BBBCABBBBAA
CBABBBABBABB
ABBBAAABBBCAA
BBBCBABBAABAB
...

correct output
Maija
Uolevi
Maija
Uolevi
Uolevi
...

user output
Maija
Uolevi
Maija
Uolevi
Uolevi
...

Test 26

Verdict: ACCEPTED

input
10000
ABAABBBBBBCAB
BBBBBBAAABBAC
BCABBBBBBBBBB
ACBAAAAAAAB
...

correct output
Maija
Uolevi
Uolevi
Uolevi
Maija
...

user output
Maija
Uolevi
Uolevi
Uolevi
Maija
...

Test 27

Verdict: ACCEPTED

input
10000
ABBCBBABABB
ABCBBBAABBBAB
ABAABBCBBABBA
BCBBBAAAAABAB
...

correct output
Maija
Uolevi
Maija
Uolevi
Maija
...

user output
Maija
Uolevi
Maija
Uolevi
Maija
...

Test 28

Verdict: ACCEPTED

input
10000
BCBBBBBBAABA
AAAAABCBABABB
ABBAACAAAABAB
AABACBAABBBA
...

correct output
Maija
Maija
Uolevi
Maija
Maija
...

user output
Maija
Maija
Uolevi
Maija
Maija
...

Test 29

Verdict: ACCEPTED

input
10000
ABAABBAABABCB
BBCBAABBBAAAA
BBBAAACBAABB
BBAAABAAACAAB
...

correct output
Maija
Maija
Uolevi
Uolevi
Maija
...

user output
Maija
Maija
Uolevi
Uolevi
Maija
...

Test 30

Verdict: ACCEPTED

input
10000
BBBBCAAAAABA
ABBABACAAABB
BAABBABACBABA
AAAAACAAABA
...

correct output
Maija
Uolevi
Uolevi
Maija
Maija
...

user output
Maija
Uolevi
Uolevi
Maija
Maija
...

Test 31

Verdict: ACCEPTED

input
8124
BCAAABABB
ABBAACABABABA
BAAABBACABBAB
BBABABBACAAAB
...

correct output
Uolevi
Maija
Uolevi
Uolevi
Maija
...

user output
Uolevi
Maija
Uolevi
Uolevi
Maija
...

Test 32

Verdict: ACCEPTED

input
1
AABBABABAAAAAABAAABBBBABAAABBA...

correct output
Maija

user output
Maija

Test 33

Verdict: ACCEPTED

input
2
BAAABBAAABBBBBBABBABBBBABABBBA...

correct output
Uolevi
Maija

user output
Uolevi
Maija

Test 34

Verdict: ACCEPTED

input
2
ABBBBBAAABBABBBBBABBBBABBBBBBB...

correct output
Maija
Maija

user output
Maija
Maija

Test 35

Verdict: ACCEPTED

input
3
ABBBABAABAABBBABBAABAAABBBBAAB...

correct output
Uolevi
Uolevi
Maija

user output
Uolevi
Uolevi
Maija

Test 36

Verdict: ACCEPTED

input
3
AABBABABABBABBBABAABBBBBAABBBB...

correct output
Maija
Maija
Uolevi

user output
Maija
Maija
Uolevi

Test 37

Verdict: ACCEPTED

input
4
ABBAAABAAABBABAAAAAAAAAAAABAAB...

correct output
Maija
Uolevi
Maija
Uolevi

user output
Maija
Uolevi
Maija
Uolevi

Test 38

Verdict: ACCEPTED

input
4
AAAAAAAAAAAAAAAAAAAABAAABAAAAA...

correct output
Uolevi
Maija
Uolevi
Uolevi

user output
Uolevi
Maija
Uolevi
Uolevi

Test 39

Verdict: ACCEPTED

input
5
BBAAAAAABAAABAABAAAAABAAAAAAAA...

correct output
Uolevi
Uolevi
Uolevi
Maija
Uolevi

user output
Uolevi
Uolevi
Uolevi
Maija
Uolevi

Test 40

Verdict: ACCEPTED

input
5
BBABBBBABABBBABAAAABBBBBBBBBBA...

correct output
Maija
Uolevi
Maija
Maija
Maija

user output
Maija
Uolevi
Maija
Maija
Maija

Test 41

Verdict: ACCEPTED

input
10
BBAAAABAAAAAAAABBAAAAAAAAAAAAA...

correct output
Uolevi
Uolevi
Maija
Maija
Maija
...

user output
Uolevi
Uolevi
Maija
Maija
Maija
...

Test 42

Verdict: ACCEPTED

input
10
BBAAABABABBBABBAAAAABABABAABAB...

correct output
Uolevi
Uolevi
Uolevi
Maija
Uolevi
...

user output
Uolevi
Uolevi
Uolevi
Maija
Uolevi
...

Test 43

Verdict: ACCEPTED

input
50
BBBBBBBBABBBBBBBBBBBBABBBBABBB...

correct output
Maija
Maija
Maija
Uolevi
Uolevi
...

user output
Maija
Maija
Maija
Uolevi
Uolevi
...

Test 44

Verdict: ACCEPTED

input
50
BBABBBBBBABAABBBBABBAAABABBABB...

correct output
Maija
Maija
Maija
Uolevi
Uolevi
...

user output
Maija
Maija
Maija
Uolevi
Uolevi
...

Test 45

Verdict: ACCEPTED

input
100
ABBBBBBBBBBBABBABBBBBBBBBBBBBB...

correct output
Maija
Uolevi
Maija
Uolevi
Maija
...

user output
Maija
Uolevi
Maija
Uolevi
Maija
...

Test 46

Verdict: ACCEPTED

input
100
ABBBBABBBAAAABBBAAAABBABAABABB...

correct output
Maija
Maija
Maija
Uolevi
Uolevi
...

user output
Maija
Maija
Maija
Uolevi
Uolevi
...

Test 47

Verdict: ACCEPTED

input
500
ABBAABBAAABAABAAAABBABBABABABA...

correct output
Maija
Maija
Uolevi
Uolevi
Uolevi
...

user output
Maija
Maija
Uolevi
Uolevi
Uolevi
...

Test 48

Verdict: ACCEPTED

input
500
ABBBBABBBBBBBBABBBBBBBBBBBBABB...

correct output
Maija
Maija
Maija
Maija
Maija
...

user output
Maija
Maija
Maija
Maija
Maija
...

Test 49

Verdict: ACCEPTED

input
1000
BAAAACAAAAAAAAAAAAAAAAAAAAAAAA...

correct output
Uolevi
Maija
Uolevi
Uolevi
Uolevi
...

user output
Uolevi
Maija
Uolevi
Uolevi
Uolevi
...

Test 50

Verdict: ACCEPTED

input
1000
BAAABAABAABAAABAAAAAAABAAAAAAA...

correct output
Uolevi
Uolevi
Uolevi
Uolevi
Maija
...

user output
Uolevi
Uolevi
Uolevi
Uolevi
Maija
...

Test 51

Verdict: ACCEPTED

input
5000
BAAAABBAABABAABAABAAAABBAAAAAA...

correct output
Uolevi
Maija
Maija
Maija
Maija
...

user output
Uolevi
Maija
Maija
Maija
Maija
...

Test 52

Verdict: ACCEPTED

input
5000
BBBBBBABABBABABBBABBBBBBBBBBAA...

correct output
Maija
Uolevi
Uolevi
Maija
Uolevi
...

user output
Maija
Uolevi
Uolevi
Maija
Uolevi
...

Test 53

Verdict: ACCEPTED

input
10000
AABAABCABBAAAB
ABBAABAAABAABAAABABBBBBABCBBBA...

correct output
Uolevi
Uolevi
Maija
Maija
Maija
...

user output
Uolevi
Uolevi
Maija
Maija
Maija
...

Test 54

Verdict: ACCEPTED

input
10000
AABBBCBBABBBABBBBBBBABBBBBBBBA...

correct output
Maija
Uolevi
Uolevi
Maija
Uolevi
...

user output
Maija
Uolevi
Uolevi
Maija
Uolevi
...

Test 55

Verdict: ACCEPTED

input
12
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA...

correct output
Uolevi
Maija
Uolevi
Uolevi
Maija
...

user output
Uolevi
Maija
Uolevi
Uolevi
Maija
...

Test 56

Verdict: ACCEPTED

input
12
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA...

correct output
Uolevi
Maija
Uolevi
Uolevi
Maija
...

user output
Uolevi
Maija
Uolevi
Uolevi
Maija
...