2-R 맞왜틀 질문있습니다.
안녕하세요.
처음에 재귀가 떠오르지 않아 반복문으로 구현을 했는데, 테스트 케이스는 전부 맞는데, 내부에서 틀린듯 합니다.
아쉽게도 다른 사람들은 77%에서 터지는데, 저는 1%에서 터지는군요...
나름 로직은 맞다고 생각하는데 백준에서 어떤 테스트가 왜 틀렸는지 알려주지 않아 답답해 여기에 질문을 올려봅니다.
제가 어떤 부분을 놓쳤나요?
http://boj.kr/55f3b362377b463397c0298ec922cdf0
답변 2
0
안녕하세요 ㅎㅎ
제가 좀 다듬으면서 고쳐봤는데요.
for (int i = target; i < amount; ++i) {
-> 이 부분이 이해가 안가는게 target부터 쭉 타고 가는 것은 올바르지만 target이3이면 3부터 10까지.. 이런식으로 하게 되면 1, 2 노드 부분은 제외되는 것 아닌가요?
해당 부분을 target부터 쭉 타고 가게 고쳐봤습니다.
int counter = 0;
for (int i = 0; i < amount; ++i) {
-> 이부분 보시면 재귀적으로 tree[tree[i]]를 기반으로 제거됨을 판단하고 있는데요. ㅎㅎ 잘하셨습니다. 좀 더 응용해서 해봤습니다.
참고부탁드립니다.
#include <bits/stdc++.h>
using namespace std;
#define ERASED -2
void eraseNode(vector<int> &tree, int target) {
tree[target] = ERASED;
for (int i = 0; i < tree.size(); ++i) {
if (tree[i] == target) {
eraseNode(tree, i);
}
}
}
int countLeafNodes(const vector<int> &tree) {
int counter = 0;
for (int i = 0; i < tree.size(); ++i) {
if (tree[i] != ERASED) {
bool isLeaf = true;
for (int j = 0; j < tree.size(); ++j) {
if (tree[j] == i) {
isLeaf = false;
break;
}
}
if (isLeaf) {
counter++;
}
}
}
return counter;
}
int main(void) {
int amount;
cin >> amount;
vector<int> tree(amount);
for (int i = 0; i < amount; ++i) {
cin >> tree[i];
}
int target;
cin >> target;
eraseNode(tree, target);
int leafCount = countLeafNodes(tree);
cout << leafCount << endl;
return 0;
}
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
0
안녕하세요, 인프런 AI 인턴입니다.
kimmistral님께서 2-R 문제 관련하여 테스트 케이스에서는 맞았지만, 백준에서 특정 테스트 케이스에서 틀리는 상황에 대해 문의주셨습니다. 백준에서 발생하는 문제들은 주로 여러 가지 이유로 발생할 수 있으며, 이는 종종 특정 엣지 케이스나 로직의 작은 오류에서 비롯됩니다.
해당 문제에 대해 자주 발생하는 오류와 해결 방법을 참고할 수 있는 몇 가지 링크를 제공해드리겠습니다. 이 자료들이 문제 해결에 조금이나마 도움이 될 수 있길 바랍니다:
일반적인 트리 문제에서 발생 가능한 실수:
- 트리의 루트 또는 단일 노드 상황에서의 반례 처리 누락.
- 노드의 삭제 및 갱신 과정에서 잊기 쉬운 상태 변경 등을 점검해보세요.
- 트리의 루트 또는 단일 노드 상황에서의 반례 처리 누락.
반복문과 재귀의 차이점에서 오는 문제:
- 반복문을 사용할 때 특정 조건이 제대로 처리되지 않는 경우가 있습니다. 이는 주로 상태 전이 과정에서 발생할 수 있습니다.
- 반복문을 사용할 때 특정 조건이 제대로 처리되지 않는 경우가 있습니다. 이는 주로 상태 전이 과정에서 발생할 수 있습니다.
유사한 문제를 겪었던 학습자들이 공유한 경험을 살펴보시면 유용할 수 있습니다. 아래 링크들은 직접적인 해결책은 아닐 수 있지만, 적어도 문제를 어떻게 접근해야 할지에 대한 인사이트를 제공할 수 있을 것입니다:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
교안 158페이지 문의드립니다
0
10
2
코딩살구클럽 관련 건의사항
0
27
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
13
1
진행 방법 질문드립니다!
0
44
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
55
2
2주차 개념#12 트리 순회
0
26
2
백준사이트가 종료된다고 합니다.
0
286
2
백준 서비스 종료
9
890
1
sk 하이닉스 코테 대비
0
367
2
3-G 최댓값 질문
0
50
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
83
2
3-I 코드 질문드립니다.
0
62
2
3-N 질문 있습니다.
0
66
2
학습방법
0
102
2
4-H 질문 있습니다 (코드 리뷰)
0
66
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
170
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
69
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
64
2
1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.
0
51
2
조합 재귀 풀이 확인 해주시면 감사하겠습니다.
0
68
2
함수별 시간복잡도
0
73
2
3-h 질문입니다.
0
49
1
안녕하세요 선생님. 시간 복잡도 4번 질문있습니다.
0
53
2
1-I 문제 질문 드립니다.
0
76
2





