본문 바로가기

전체 글

(161)
[TIL] 24.04.18 알고리즘 1. 알고리즘 문제 해결 2x2x2 큐브(백준 16939): 단순 구현 문제. 이건 사실 왜 골드2로 책정된건지 조금 의아했다. 잘쳐줘도 실버 하위정도의 난이도를 가진 문제같은데.. 한 번 돌려서 풀 수 있는지를 묻고 있기 때문에, 단순 구현으로 빠르게 처리할 수 있다. 각 축에 대해 한 쪽을 시계방향으로 회전하는 경우와 반시계방향으로 회전하는 경우, 그래서 따져봐야하는 경우는 6가지이다. 축 별로 한쪽 방향 회전을 만들어둔 후, 세 번 반복하면 반대쪽 방향 회전한 결과와 같기 때문에 그걸 이용해서 풀어도 되지만, 그렇게 하려면 각 칸 배열의 수들을 옮기는 회전 함수를 이용해야 한다. 하지만 굳이 배열에 매번 바뀌는 값을 assign해서 상태를 검사하는 것보단, 단순하게 6가지 케이스들은 초기 배열을 이..
[Android] Kotlin DSL 이용 시, API Key 은닉하기(AGP 9.0 미만) 흔히 토이 프로젝트 등을 할 때 api 키와 같은 정보를 local.properties에 은닉하곤 하는데 groovy를 사용할 때와 소소한 차이가 있어서, 오랜만에 작성하면 낯설게 느껴진다. 이번 기회에 글로 남기면서 정리하려고 한다. 1. local.properties에 키 값 작성하기 local.properties에 키 값을 이름=문자열 꼴로 작성한다. 당연히 이 파일은 형상 관리 시스템에서 제외되어야 한다. 2. 앱 수준 build.gradle에서 Properties 객체 생성 후, local.properties 파일 불러오기 사실 파일이 존재하는지 한번 확인하면 더 견고한 프로그램이 될 것 같다. 3. buildConfig에 등록하기 defaultConfig에서 지정하긴 했지만, 당연히 build..
[TIL] 24.04.17 알고리즘, Activity와 Fragment 전환 시 생명주기 차이 1. 알고리즘 문제 해결 퍼즐(백준 1525): BFS 문제이긴 한데, 학교 알고리즘 수업을 들을 때 비슷한 문제를 A* 알고리즘을 적용해 풀었던 기억이 있어서 A* 알고리즘으로 풀어보았다. A* 알고리즘 f(x) = g(x) + h(x)라고 하고, h(x)를 휴리스틱 함수라고 할 때, g(x)는 현재까지의 이동 횟수로, h(x)는 완성된 퍼즐과의 일치 정도로 설정했다. 메모리 제한이 32MB로 꽤나 빠듯하기 때문에, 탐색 과정에서 퍼즐정보를 2차원 정수 배열로 담았다간 우선순위 큐에 원소가 쌓이며 메모리 초과가 나기 십상일 것이다. 그래서 어떡할까 하다가 문자열을 이용하기로 했다. 9글자짜리 문자열은 비교적 적은 메모리를 차지할 것이라고 생각했기 때문이다. 만약 그럼에도 초과가 난다면 Int형 하나만 ..
[TIL] 24.04.16 알고리즘, 앱개발 숙련 주차 개인과제 제출 1. 알고리즘 문제 해결 정육면체 전개(백준 1917): 구현 문제였는데 말끔한 로직을 떠올리기 쉽지 않았다. 주어진 전개도에 대해 정육면체의 전개도임을 판별할 수 있는 수식이 떠오르지 않았기 때문이다. 둘레부터 시작해서, 모서리의 수, 전개도 내의 배열의 특징성 등을 떠올려봐도 정육면체의 전개도만을 판별해낼 수 있는 일반화된 식은 전혀 없었다. 그래서 시뮬레이션 방식으로 답을 찾아나가는 법 밖에는 없었다. 일단 어느정도 복잡도를 가진 로직을 사용할 지는 몰랐지만, 아무래도 2차원 배열로 데이터가 주어지고 그 중 정사각형이 존재하는 부분만 이용하게 될 것 같았고 그렇다면 DFS/BFS와 같은 탐색류가 메인이 될 가능성이 높아보였다. 입력 데이터의 크기는 항상 6*18의 작은 크기로 주어지므로, 설령 완전..
[TIL] 24.04.15 알고리즘, 앱개발 숙련 주차 개인과제 1. 알고리즘 문제 해결 Ah-Choo!(백준 15822): DP 문제이다. 점화식을 찾는 것이 제일 까다로웠다. 처음에 두 파형에 대해서 대응되는 시점을 지정하는 과정을 잘못 이해해서 시간을 더 쓰게 된 것 같다. 시점이 N개이면 대응 관계도 N개만 존재해야 하는 줄 알았는데, 문제를 다시 읽어보니 그런 제한은 명시돼있지 않았고, 오히려 각 시점은 하나 이상의 대응되는 시점을 가져야 한다는 조건이 핵심이었다. 그렇게 생각한다면, 점화식을 찾기 한결 편해진다. 파형 X의 시점 i와 파형 Y의 시점 j를 대응시킨다고 생각하면 고려할 경우는 세 가지이다. - 파형 X의 시점 i-1과 파형 Y의 시점 j-1이 대응되었던 경우 - 파형 X의 시점 i-1과 파형 Y의 시점 j가 대응되었던 경우 - 파형 X의 시점..
[TIL] 24.04.12 알고리즘, 앱개발 숙련 주차 개인과제 1. 알고리즘 문제 해결 구간 나누기(백준 2228): 일정 난이도를 넘어가기 시작하면 주어지는 n이 작을 때가 더 두렵다. 단순하게 로직하나 돌려서 끝나지 않고, 완전탐색이나 다른 탐색류 알고리즘이 더해지는 경우가 많아서다. 이번 문제는 큰 틀이 dp라는 것을 파악하는 데는 어려움이 없었지만, 그래서 결국 복수개의 구간합을 어떻게 dp로 풀어낼 것인지가 아리송했다. 주어진 배열 내에서 하나씩 순회해가며 탐색 중인 인덱스를 기점으로 구간이 0~M개까지 선택되는 경우을 찾아야 하는 것은 분명했다. 여기서 dp라는 틀에 얽매여서, Bottom-Up Approach만 떠올리느라 한참 시간을 보낸 것 같다. 긴 고민 끝에 풀어낸 방법은 오히려 Top-Down Approach를 이용하는 것이었다. N*M 크기의 ..
[TIL] 24.04.11 알고리즘, 개인 과제 Dialog 에러 1. 알고리즘 문제 해결 연속합 2(백준 13398): 브루트 포스로 구한다면 O(n^2)의 시간복잡도를 가지기 때문에, 시간 제한 내로 풀 수 없다. DP를 이용해야 하는 문제. 수열에서 수를 하나 제거할 수 있다는 조건 때문에, 1차원 배열 하나로는 풀 수 없고 1차원 배열 두 개를 이용해야 한다. 하나는 일반적인 경우의 연속합을 계산해 저장하고, 하나는 수를 하나 제거했을 때의 연속합을 저장한다. 먼저 일반적인 경우의 연속합은 max(이전까지의 연속합+탐색중인 수, 탐색 중인 수)로 구할 수 있다. 이전까지의 연속합이 음수라면 현재 탐색 중인 수부터 새로 연속합을 구하는 것이 optimal한 값이기 때문이다. 두번째로 수열에서 수를 하나 제거한 경우의 연속합은, max(이전까지의 연속합, 이전까지의..
[TIL] 24.04.09 알고리즘, 앱개발 숙련 주차 1. 알고리즘 문제 해결 LCS 2(백준 9252): 오랜만에 따로 알고리즘 문제를 풀었다. 캠프의 루틴에 따라 매일 매일 프로그래머스의 알고리즘 문제를 하나씩 풀고있긴 하지만, 결이 좀 다르다. 제시된 문제들이 비교적 간단하고, 백준 문제들처럼 입력과 출력, 제한 시간 및 메모리 등이 확실하게 주어지지 않는 문제도 많아서 알고리즘 사고를 연습하기 보다는 코틀린에 더 익숙해지는 용도로 쓰고 있다. 한동안 팀 프로젝트를 진행하느라, 개인적으로 이렇게 알고리즘 문제를 풀지 못했는데 오랜만에 푸니까 더 재밌게 느껴지는 것 같다. 이 문제는 알고리즘 과목을 수강하면 DP를 배우면서 한번쯤은 공부하는 문제가 아닐까 생각한다. 브루트 포스로 해결하자면 각각의 문자열의 길이가 n과 m이라고 했을 때, 시간복잡도가 O..