쇠막대기 오답 질문
232
작성한 질문수 2
닫는 괄호를 만날 때마다 count++를 해주는 방식은 왜 정답이 안나오는 지 알 수 있을까요?
import java.util.Scanner;
import java.util.Stack;
public class Main {
public static int solution(String str){
int answer = 0;
char[] strTochars = str.toCharArray();
Stack<Character> stack = new Stack<>();
int count = 0;
for (int i=0; i<strTochars.length; i++) {
if (strTochars[i] == '(') stack.push('(');
else {
if (!stack.isEmpty() && stack.peek() == '(') {
stack.pop();
count ++;
if (i>0 && strTochars[i-1] != '(') { // 막대
answer += count;
count = 0;
}
}
}
}
return answer;
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String str = sc.nextLine();
System.out.println(solution(str));
}
}
답변 1
0
안녕하세요, 인프런 AI 인턴이에요.
제가 보았을 때, 코드는 충분히 정확해 보입니다. 그러나 답이 나오지 않는 이유는 count 변수를 잘못 처리했기 때문입니다.
주어진 코드에서는 막대기의 길이를 구하는 것이 목적인 것으로 보입니다. 막대기가 끝날 때마다 count 변수를 0으로 초기화하여 다음 막대기의 길이를 구합니다. 하지만 현재 코드에서는 닫는 괄호를 만날 때마다 count 변수를 초기화하고 있습니다.
따라서, 막대기의 길이를 구하기 위해서는 닫는 괄호를 만났을 때 count 변수를 초기화하는 것이 아니라, 열리는 괄호를 만났을 때 count 변수를 초기화해야 합니다.
아래의 코드를 참고해보세요.
import java.util.Scanner;
import java.util.Stack;
public class Main {
public static int solution(String str){
int answer = 0;
char[] strTochars = str.toCharArray();
Stack<Character> stack = new Stack<>();
int count = 0;
for (int i=0; i<strTochars.length; i++) {
if (strTochars[i] == '(') {
stack.push('(');
count = 0; // 열리는 괄호를 만나면 count 변수를 초기화
}
else {
if (!stack.isEmpty() && stack.peek() == '(') {
stack.pop();
count ++;
if (i>0 && strTochars[i-1] != '(') { // 막대
answer += count;
}
}
}
}
return answer;
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String str = sc.nextLine();
System.out.println(solution(str));
}
}
이렇게 수정하면, 막대기의 길이를 올바르게 구할 수 있을 거예요. 그럼 원하시는 결과를 얻을 수 있도록 도움이 되었길 바랄게요. 더 궁금한 점이 있으면 언제든지 물어보세요. 좋은 하루 되세요.
안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.
0
28
1
갑자기 채점 사이트가 바뀌었어요
0
32
1
문제 리스트 페이지
0
29
1
채점 사이트 관련 질문드립니다
0
24
1
봉우리 문제 질문입니다
0
81
2
씨름 선수 문제에서 각 선수의 몸무게나 키가 같을 수도 있다면?
0
65
0
이 코드랑 영상 코드중에 뭐가 더 좋은 코드인가요?
0
72
0
가중치 방향 그래프에서 가중치가 0인 간선을 표현하는 방법
0
67
1
좌표 정렬 문제 이 코드가 왜 틀린지 모르겠습니다 ㅠㅠ
0
85
2
6-7 강의에서
0
48
1
6-6. 장난꾸러기 질문 있습니다.
0
45
1
강의 수강후 코딩테스트
0
110
1
answer 변수 사용 여부
0
45
1
2중 for문
1
85
2
2-11. 임시반장정하기 (Runtime Error)
0
63
1
혹시 LinkedList 같은 자료 구조들은 따로 배우지 않나요?
0
70
1
이런 풀이는 어떨까요
0
44
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





