SWEA_8500) 극장 좌석

8500) 극장 좌석 (19.10.21)


문제 링크 (SW Expert Academy)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
import java.io.*;
import java.util.*;

public class Solution {
    public static void main(String args[]) throws IOException{
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
        StringTokenizer tk;
        
        int test = Integer.parseInt(br.readLine());
        for(int t=1; t<=test; t++) {
            int n = Integer.parseInt(br.readLine());
            
            int[] arr = new int[n];
            tk = new StringTokenizer(br.readLine());
            
            for(int i=0;i<n;i++) {
                arr[i] = Integer.parseInt(tk.nextToken());
            }
            
            Arrays.sort(arr);
            
            int ans = n+ arr[0]+ arr[1];
            
            for(int i=2;i<n;i++) {
                if(i==n-1) ans = ans+ (arr[i]*2);
                else ans = ans+ arr[i];
            }
            
            bw.write("#" + t + " " + ans + "\n");
        }
        
        bw.flush();
        bw.close();
    }
}
cs



* 양 끝의 빈 좌석 개수를 가장 작은 숫자로 설정하고,
* 사람들 사이의 빈 좌석 개수를 계산 할 때는 가장 큰 숫자는 항상 선택되니까
* 그걸 두번 더해주고 나머지는 한번씩 더해주면 된다.

* 어떻게 하나 생각하다가 사람이 번호순대로 앉은게 아니라고 해서 식을 만들어봤다.

댓글

이 블로그의 인기 게시물