본문 바로가기

자바173

[Java] SWEA 7854번 최약수 SW Expert Academy SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요! swexpertacademy.com 풀이 최약수를 구해보면 한자리의 숫자는 1, 2, 5 두자리의 숫자는 10, 20, 25, 50 세자리이상의 숫자는 100...0, 125...0, 200...0, 250...0, 500...0 이 됩니다. 우선 입력받은 숫자의 자리수 이하의 최약수는 전부 포함되야하므로 작은 자리수의 최약수의 개수를 모두 더해주었습니다. 다음으로 한자리일 경우 각 자리수의 최약수를 저장한 num배열의 1행을, 두자리일 경우 2행을, 세자리 이상일 경우 3행을 이용해서 최약수보다 입력받은 수가 크거나 같으면 해당 최약수는 포함되므로 개수를 +1하여 해결했습니다. 이때, 세자리 이상.. 2021. 3. 11.
[Java] SWEA 6719번 성수의 프로그래밍 SW Expert Academy SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요! swexpertacademy.com 풀이 처음에는 순열로 접근했다가 시간초과가 발생해서 문제를 다시 보았는데 굳이 순열을 쓸 필요없이 입력받은 과목의 수준을 정렬해서 숫자가 큰 순서대로 K개를 뽑아 K개에서 가장 작은 수 부터 실력을 갱신하여 해결했습니다. 코드 import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.Arrays; import java.util.StringTokenizer; public class Solution { public static i.. 2021. 3. 10.
[Java] SWEA 1238번 Contact SW Expert Academy SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요! swexpertacademy.com 풀이 문제에서 요구한 연락이 퍼지는 속도는 일정하다는 규칙이 있기에 bfs를 사용하여 해결했습니다. 간선을 입력받을 때에는 ArrayList를 사용하여 동적으로 할당받을 수 있게 했습니다. 또한, visit를 이용하여 각 정점마다의 연락받은 순번을 저장하여 문제에서 요구한 정답을 찾을 수 있게 했습니다. 코드 import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.ArrayList; import java.util.Linked.. 2021. 3. 9.
[Java] SWEA 1218번 괄호 짝짓기 SW Expert Academy SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요! swexpertacademy.com 풀이 스택을 이용해서 괄호가 옳바른 괄호인지 체크하고 만약 마지막에 스택이 비어있지 않다면 괄호의 짝이 맞지 않게되므로 정답을 0으로 바꾸어주어 해결했습니다. 코드 import java.io.BufferedReader; import java.io.InputStreamReader; import java.util.Stack; public class Solution { public static char[] brackets; public static void main(String[] args) throws Exception { BufferedReader br = new .. 2021. 3. 8.
[Java] SWEA 1868번 파핑파핑 지뢰찾기 SW Expert Academy SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요! swexpertacademy.com 풀이 우선 8면이 전부 숫자인 부분들만 찾아서 dfs를 통해 숫자를 공개하면서 클릭 횟수를 증가시키고 전부 숫자로 둘러쌓인 부분을 다 찾으면 남아있는 '.' 부분을 찾아 클릭 횟수를 증가시키는 방법으로 해결했습니다. 코드 import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; public class Solution { public static int N, answer; public static char[][] table; public static void.. 2021. 3. 5.
[Java] ArrayList의 2차원 배열 ArrayList를 2차원 배열처럼 사용할 때 우선 ArrayList 자료형 배열을 만들고 각 배열의 인덱스를 직접 초기화 해서 사용하면 됩니다. List[] arr = new ArrayList[N + 1]; for (int i = 0; i < N; ++i) { arr[i] = new ArrayList(); } 2021. 3. 4.