[최대 길이 연속부분수열] 틀린 이유
440
작성한 질문수 3
import java.util.*;
class Main {
public int solution(int n, int m, int[] arr) {
int lt = 0, sum = 0, max = 0, count = 0;
for(int rt = 0; rt < n; rt++) {
if(arr[rt] == 1) {
sum += arr[rt];
} else if (arr[rt] == 0) {
if(count++ < m) {
sum += 1;
} else {
if (sum >= max) {
max = sum;
sum = 0;
lt ++;
rt = lt;
count = 0;
}
}
}
}
return max;
}
public static void main(String[] args) {
Main T = new Main();
Scanner in = new Scanner(System.in);
int n = in.nextInt();
int m = in.nextInt();
int[] arr = new int[n];
for(int i = 0; i < n; i++) {
arr[i] = in.nextInt();
}
System.out.print(T.solution(n, m, arr));
}
}논리적으로 틀린건 없는거 같고, 예시코드도 틀린게 없는데 왜 오답이 나오는지 모르겠습니다 !!
답변 1
0
안녕하세요, 인프런 AI 인턴입니다.
Park Jiho님, 제시하신 코드를 살펴보았습니다.
코드에는 논리적 오류가 있습니다. 0을 만날 때 count가 m보다 작다면 sum에 1을 더해주시고, 그렇지 않은 경우 max 값을 갱신한 후 sum을 0으로 초기화하고 lt와 rt를 조절하는 부분에서 문제가 발생합니다. 이부분에서 오류가 있는 것으로 보입니다.
올바른 투 포인터 알고리즘 접근법은 다음과 같습니다:
1. 연속된 0의 개수가 m을 넘지 않도록 유지하면서 rt 포인터를 오른쪽으로 이동합니다.
2. 연속된 0의 개수가 m을 초과하면 lt를 오른쪽으로 이동시키면서 연속된 0의 개수가 다시 m이하가 될 때까지 조정합니다.
3. 이 과정에서 rt - lt + 1 (현재 연속 부분 수열의 길이)의 최댓값을 갱신합니다.
아래는 수정된 코드의 예시입니다:
import java.util.*;
class Main {
public int solution(int n, int m, int[] arr) {
int answer = 0, cnt = 0, lt = 0;
for (int rt = 0; rt < n; rt++) {
if (arr[rt] == 0) cnt++;
while (cnt > m) {
if (arr[lt] == 0) cnt--;
lt++;
}
answer = Math.max(answer, rt - lt + 1);
}
return answer;
}
public static void main(String[] args) {
Main T = new Main();
Scanner in = new Scanner(System.in);
int n = in.nextInt();
int m = in.nextInt();
int[] arr = new int[n];
for (int i = 0; i < n; i++) {
arr[i] = in.nextInt();
}
System.out.print(T.solution(n, m, arr));
}
}
이 코드는 lt 포인터가 rt 포인터를 따라가며 연속된 수열 중 0의 개수가 m을 넘지 않을 때 최대 길이를 계산합니다.
위 코드를 참고하여 문제를 해결해 보시기 바랍니다.
안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.
0
27
1
갑자기 채점 사이트가 바뀌었어요
0
32
1
문제 리스트 페이지
0
27
1
채점 사이트 관련 질문드립니다
0
23
1
봉우리 문제 질문입니다
0
81
2
씨름 선수 문제에서 각 선수의 몸무게나 키가 같을 수도 있다면?
0
64
0
이 코드랑 영상 코드중에 뭐가 더 좋은 코드인가요?
0
72
0
가중치 방향 그래프에서 가중치가 0인 간선을 표현하는 방법
0
67
1
좌표 정렬 문제 이 코드가 왜 틀린지 모르겠습니다 ㅠㅠ
0
85
2
6-7 강의에서
0
48
1
6-6. 장난꾸러기 질문 있습니다.
0
45
1
강의 수강후 코딩테스트
0
109
1
answer 변수 사용 여부
0
44
1
2중 for문
1
85
2
2-11. 임시반장정하기 (Runtime Error)
0
63
1
혹시 LinkedList 같은 자료 구조들은 따로 배우지 않나요?
0
70
1
이런 풀이는 어떨까요
0
43
1
자바 스트림 방식의 효율성 질문 드립니다.
0
57
1
알고리즘 자료 구조들..
0
62
1
StringBuilder vs BufferdWriter
0
48
1
원더랜드(프림)
0
50
1
이런 코드는 어떤가요?
0
61
1
bfs 풀이
0
57
1
병합정렬
0
56
1





