CSES - Datatähti 2017 alku - Results
Submission details
Task:Bittijono
Sender:lumieer
Submission time:2016-10-09 19:59:16 +0300
Language:Java
Status:READY
Result:0
Feedback
groupverdictscore
#10
#20
#30
Test results
testverdicttimegroup
#10.12 s1details
#20.14 s2details
#30.14 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 < luvutJonossa.length(); 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");
            return;
        }
        
               
        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
                List<Integer> tutkittavaLista = lista.subList(0, lista.lastIndexOf(viimeisinLuku) + 1);
                //System.out.println("Tutkittavan listan koko " + tutkittavaLista.size());
                boolean lukuMuodostettu = false;
                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);
                        if (alkiotYhteen(tutkittavaLista.subList(a, b + 1)) == i) {
                            lukuMuodostettu = true;
                            break;
                        }
                        if (tutkittavaLista.get(a) + tutkittavaLista.get(b) == i) {
                            lukuMuodostettu = true;
                            break;
                        }
                    }
                    if (lukuMuodostettu) {
                        break;
                    }
                }
                if (!lukuMuodostettu) {
                    //System.out.println("Ei muodostettu");
                    return i;
                }
            }
        }
        //System.out.println("PERKELE");
        return lista.get(lista.size() - 1) + 1;
    }
    
    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
100
62
9
12
73
...

correct output
1
1
1
0
1
...

user output
(empty)

Test 2

Group: 2

Verdict:

input
100000
565433
141881
120108
825392
...

correct output
1
1
0
0
1
...

user output
(empty)

Test 3

Group: 3

Verdict:

input
100000
374768524402011755
937067109466254318
389256426086302899
932585725667010169
...

correct output
0
1
1
1
1
...

user output
(empty)