smooth waters run deep

1d-1c/BOJ

9613_GCD 합 (JAVA)

yeon_11 2020. 11. 22. 21:22
 

9613번: GCD 합

첫째 줄에 테스트 케이스의 개수 t (1 ≤ t ≤ 100)이 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있다. 각 테스트 케이스는 수의 개수 n (1 < n ≤ 100)가 주어지고, 다음에는 n개의 수가 주어진

www.acmicpc.net

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.*;

public class Main {
	public static void main(String[] args) throws Exception{
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st;

		int testcase = Integer.parseInt(br.readLine());
		for(int i=0; i<testcase; i++){
			st = new StringTokenizer(br.readLine());

			int tokencount = st.countTokens();
			int n = Integer.parseInt(st.nextToken());

			int[] num = new int[tokencount-1];
			for(int j=0; j<tokencount-1; j++){
				num[j] = Integer.parseInt(st.nextToken());
			}

			int[] ssang = new int[2];
			List<Integer> ans = new ArrayList<>();

			func(num, ssang, 0, 0, ans);

			long sum = 0;
			Iterator<Integer> it = ans.iterator();
			while(it.hasNext()){
				sum += it.next();
			}
            
			System.out.println(sum);
		}
	}

	private static void func(int[] num, int[] ssang, int num_index, int ssang_index, List<Integer> ans){
		if(ssang_index == 2){
			ans.add(gcd(ssang[0], ssang[1]));
			return;
		}
		if(num_index >= num.length)
			return;

		ssang[ssang_index] = num[num_index];
		func(num, ssang, num_index+1, ssang_index+1, ans);
		func(num, ssang, num_index+1, ssang_index, ans);
	}

	private static int gcd(int x, int y) {
		while(x>0){
			int temp = y%x;
			y = x;
			x = temp;
		}
		return y;
	}
}

 

1. num[] 원소를 2개 택하는 모든 경우를 조합으로 구한다. : func()함수

2. 2개를 택했을 때, 최대공약수를 구하고 ans리스트에 넣는다.

3. 총 합 출력하면 끝

 

** 정답은 int형의 범위를 넘어갈 수 있다. long형으로 선언해야 한다.

 

'1d-1c > BOJ' 카테고리의 다른 글

14500_테트로미노 (JAVA)  (0) 2020.11.23
6588_골드바흐의 추측 (JAVA)  (0) 2020.11.22
1934_최소공배수 (JAVA)  (0) 2020.11.22
1652_누울 자리를 찾아라 (JAVA)  (0) 2020.11.19
1764_듣보잡 (JAVA)  (0) 2020.11.19