CSES - Datatähti 2017 alku - Results
Submission details
Task:Kolikot
Sender:lumieer
Submission time:2016-10-10 19:50:28 +0300
Language:Java
Status:READY
Result:0
Feedback
groupverdictscore
#10
#20
#30
Test results
testverdicttimegroup
#10.14 s1details
#2ACCEPTED0.12 s1details
#30.14 s1details
#4ACCEPTED0.14 s1details
#50.15 s1details
#60.12 s2details
#7ACCEPTED0.14 s2details
#8ACCEPTED0.13 s2details
#90.14 s2details
#100.14 s2details
#110.35 s3details
#12ACCEPTED0.30 s3details
#13ACCEPTED0.37 s3details
#14--3details
#150.37 s3details
#160.38 s3details

Code

//package kolikot;

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class Kolikot {

    public static void main(String[] args) {
        ArrayList<Integer> luvut = new ArrayList<>();
        final Scanner lukija = new Scanner(System.in);

        int maara = Integer.parseInt(lukija.nextLine());

        String luvutJonossa = lukija.nextLine();

        //System.out.println(luvutJonossa.length());

        int tempLuku = 0;
        for (int i = 0; i < maara * 2 - 1; i++) {
            if (Character.getNumericValue(luvutJonossa.charAt(i)) > -1) {
                //System.out.println(tempLuku);
                tempLuku *= 10;
                tempLuku += Character.getNumericValue(luvutJonossa.charAt(i));
            } else {
                luvut.add(tempLuku);
                //System.out.println("Lisattiin " + tempLuku);
                tempLuku = 0;
            }
        }

        luvut.add(tempLuku);

        //System.out.println("Lisattiin " + tempLuku);

        luvut.sort(null);
        
        /*
        //System.out.println("Tulostetaan lista");
        for (int luku : luvut) {

            System.out.print(luku);

        }
        System.out.println("");
        */
        
        //Jos ei lukua 1, se pienin
        if (luvut.get(0) != 1) {
            System.out.println("1");
        } else {
            System.out.println(etsiPienin(luvut));
        }

    }

    public static int etsiPienin(List<Integer> lista) {
        int viimeisinLuku = 0;
        for (int i = 1; i <= lista.get(lista.size() - 1); i++) {
            if (lista.contains(i)) {
                //Seuraava
                viimeisinLuku = i;

                //System.out.println("Sisaltaa " + i);

            } else {
                //System.out.println("Ei sisalla " + i);
                //Tutkitaan, voidaanko i:ta muodostaa
                int tulos = tutkiLista(lista.subList(0, lista.lastIndexOf(viimeisinLuku) + 1), i);
                if (tulos != 0) {
                    return tulos;
                } 
            }
        }
        return lista.get(lista.size() - 1) + 1;
    }

    public static int tutkiLista(List<Integer> tutkittavaLista, int i) {
        //System.out.println("Tutkittavan listan koko " + tutkittavaLista.size());
        boolean lukuMuodostettu = false;
        int kokoListaYhteen = alkiotYhteen(tutkittavaLista);
        for (int a = 0; a < tutkittavaLista.size() - 1; a++) {
            //System.out.println("Ylempi for k." + a);
            for (int b = a + 1; b < tutkittavaLista.size(); b++) {
                //System.out.println("Alempi for k." + b);
                int yhteen = alkiotYhteen(tutkittavaLista.subList(a, b + 1));            
                if (yhteen == i) {
                    //System.out.println("Alkio " + i + " voidaan muodostaa");
                    lukuMuodostettu = true;
                    break;
                }
                if (kokoListaYhteen - yhteen == i) {
                    //System.out.println("Alkio " + i + " voidaan muodostaa");
                    lukuMuodostettu = true;
                    break;
                }
                if (tutkittavaLista.get(a) + tutkittavaLista.get(b) == i) {
                    //System.out.println("Alkio " + i + " voidaan muodostaa");
                    lukuMuodostettu = true;
                    break;
                }
            }
            if (lukuMuodostettu) {
                break;
            }
        }
        if (!lukuMuodostettu) {
            //System.out.println("Ei muodostettu");
            return i;
        }
        return 0;
    }

    public static int alkiotYhteen(List<Integer> lista) {
        int vastaus = 0;
        for (int luku : lista) {
            vastaus += luku;
        }
        //System.out.println("Alkiot yhteen: " + vastaus);
        return vastaus;
    }
}

Test details

Test 1

Group: 1

Verdict:

input
10
5 3 1 4 5 1 3 2 2 3

correct output
30

user output
6

Test 2

Group: 1

Verdict: ACCEPTED

input
10
3 5 5 4 5 4 5 5 5 3

correct output
1

user output
1

Test 3

Group: 1

Verdict:

input
10
10 9 2 8 7 10 7 1 5 2

correct output
62

user output
4

Test 4

Group: 1

Verdict: ACCEPTED

input
10
7 4 6 3 9 7 4 4 7 7

correct output
1

user output
1

Test 5

Group: 1

Verdict:

input
10
8 2 1 7 9 7 5 2 4 5

correct output
51

user output
10

Test 6

Group: 2

Verdict:

input
100
3 3 1 4 2 1 2 1 3 1 2 5 1 5 1 ...

correct output
269

user output
6

Test 7

Group: 2

Verdict: ACCEPTED

input
100
3 3 2 3 4 5 4 4 4 4 2 2 4 4 4 ...

correct output
1

user output
1

Test 8

Group: 2

Verdict: ACCEPTED

input
100
678 999 374 759 437 390 832 54...

correct output
1

user output
1

Test 9

Group: 2

Verdict:

input
100
862 537 633 807 666 248 237 5 ...

correct output
30

user output
17

Test 10

Group: 2

Verdict:

input
100
874 302 384 920 76 28 762 163 ...

correct output
41765

user output
1

Test 11

Group: 3

Verdict:

input
100000
4 2 5 3 2 3 5 2 2 2 3 4 3 3 2 ...

correct output
299640

user output
6

Test 12

Group: 3

Verdict: ACCEPTED

input
100000
2 5 5 5 5 2 4 4 3 2 3 2 5 5 3 ...

correct output
1

user output
1

Test 13

Group: 3

Verdict: ACCEPTED

input
100000
98146842 766872135 84108268 28...

correct output
1

user output
1

Test 14

Group: 3

Verdict:

input
100000
932032495 1 849176169 78948957...

correct output
29970

user output
(empty)

Test 15

Group: 3

Verdict:

input
100000
35894853 796619259 699878597 4...

correct output
44965249639582

user output
1

Test 16

Group: 3

Verdict:

input
100000
930494676 960662779 904422858 ...

correct output
800020001

user output
2