티스토리 뷰
Algorithm/LeetCode
[LeetCode - Daily Challenge] 698. Partition to K Equal Sum Subsets
Jaime.Lee 2021. 10. 1. 10:48Problem
Given an integer array nums and an integer k, return true if it is possible to divide this array into k non-empty subsets whose sums are all equal.
Example 1:
Input: nums = [4,3,2,3,5,2,1], k = 4
Output: true
Explanation: It's possible to divide it into 4 subsets (5), (1, 4), (2,3), (2,3) with equal sums.
Example 2:
Input: nums = [1,2,3,4], k = 3
Output: false
Constraints:
- 1 <= k <= nums.length <= 16
- 1 <= nums[i] <= 10^4
- The frequency of each element is in the range [1, 4].
Solution
주어진 배열을 비어있지 않은 K개의 부분 배열로 나눌 때 각 부분 배열의 합이 동일하게 나눌 수 있는지 확인하는 문제입니다.
먼저 동일하게 나눌 수 없는 조건을 확인하려면 배열의 원소들을 모두 합한 값이 K로 나누어 떨어져야 합니다.
K로 나누어 떨어지는 경우 값이 모두 같아야 하기 때문에 합 / K가 목표하는 값이 됩니다.
이 목표하는 값을 부분 배열의 원소들을 더해서 만족시킬 수 있는지, 그리고 그 부분 배열의 갯수가 K개가 나오는지는 DFS (Depth First Search) 알고리즘을 이용해 구할 수 있습니다.
public class Solution {
public boolean canPartitionKSubsets(int[] nums, int k) {
int sum = 0;
for (int num : nums) {
sum += num;
}
if (sum % k != 0) {
return false;
}
return dfs(nums, 0, 0, 0, sum / k, k, new boolean[nums.length]);
}
private boolean dfs(int[] nums, int index, int sum, int count, int target, int k, boolean[] visited) {
if (k == 1) {
return true;
}
if (sum == target && count > 0) {
return dfs(nums, 0, 0, 0, target, k - 1, visited);
}
for (int i = index; i < nums.length; i++) {
if (!visited[i]) {
visited[i] = true;
if (dfs(nums, i + 1, sum + nums[i], count + 1, target, k, visited)) {
return true;
}
visited[i] = false;
}
}
return false;
}
}
DFS 관련해서는 저도 매번 헷갈려서 하루 날잡고 정리할 예정입니다.
Test
package io.lcalmsky.leetcode.partition_to_k_equal_sum_subsets;
import org.junit.jupiter.api.Test;
import static org.junit.jupiter.api.Assertions.assertAll;
import static org.junit.jupiter.api.Assertions.assertEquals;
class SolutionTest {
@Test
void givenPositiveNumbersAndK_whenCheckWhetherItsPossibleToDivideIntoSubsetsWithEqualSum_thenCorrect() {
assertAll(
() -> test(new int[]{4, 3, 2, 3, 5, 2, 1}, 4, true),
() -> test(new int[]{1, 2, 3, 4}, 3, false)
);
}
private void test(int[] nums, int k, boolean expected) {
// when
Solution solution = new Solution();
boolean actual = solution.canPartitionKSubsets(nums, k);
// then
assertEquals(expected, actual);
}
}
'Algorithm > LeetCode' 카테고리의 다른 글
[LeetCode - Daily Challenge] 55. Jump Game (0) | 2021.10.04 |
---|---|
[LeetCode - Daily Challenge] 174. Dungeon Game (0) | 2021.10.02 |
[LeetCode - Daily Challenge] 725. Split Linked List in Parts (0) | 2021.09.30 |
[LeetCode - Daily Challenge] 922. Sort Array By Parity II (0) | 2021.09.29 |
[LeetCode - Daily Challenge] 1137. N-th Tribonacci Number (0) | 2021.09.24 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 스프링 부트 회원 가입
- Spring Data JPA
- Spring Boot
- gRPC
- JPA
- spring boot application
- 클린 아키텍처
- intellij
- Spring Boot Tutorial
- 스프링 데이터 jpa
- Spring Boot JPA
- 스프링 부트 튜토리얼
- 스프링 부트 애플리케이션
- 스프링 부트
- QueryDSL
- spring boot app
- 함께 자라기 후기
- r
- Linux
- Jackson
- Java
- proto3
- spring boot jwt
- JSON
- 알고리즘
- 함께 자라기
- 스프링부트
- leetcode
- @ManyToOne
- 헥사고날 아키텍처
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함