인프런 커뮤니티 질문&답변

박희천님의 프로필 이미지
박희천

작성한 질문수

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

3-N

3-N 비효율적으로 풀었는데 이렇게 접근해도 되나요?

해결된 질문

작성

·

253

0

안녕하세요 큰돌님,

다름이 아니고 3-N 완전이진 트리문제 이거 정석적인 방법이 잘 안떠올라서 무식하게 풀었는데 이렇게 풀어도 괜찮은가요?

항상 문제 먼저 풀어보고 안풀리면 큰돌님 영상보는 식으로 학습중이거든요.... 이번에는 영상 보기전에 풀어서 통과가 되었지만 이런 방식으로 문제에 접근해도 괜찮은 건지 여쭙니다.

 

#include <bits/stdc++.h>

using namespace std;
int K, ksize, input;
vector<vector<int>> result;
vector<int> v;

int main()
{
  cin >> K;
  ksize = pow(2, K) - 1;

  for (int i = 0; i < ksize; ++i)
  {
    cin >> input;
    v.push_back(input);
  }

  while (v.size())
  {
    vector<int> temp;
    for (int i = 0; i < v.size(); i += 2)
    {
      temp.push_back(v[i]);
    }
    result.push_back(temp);
    for (int i = v.size() - 1; i >= 0; i--)
    {
      if (i % 2 == 0)
      {
        v.erase(v.begin() + i);
      }
    }
  }

  for (auto i = result.rbegin(); i != result.rend(); ++i)
  {
    for (const auto &n : *i)
    {
      cout << n << ' ';
    }
    cout << '\n';
  }

  return 0;
}

답변 2

1

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 희천님 ㅎㅎ

나쁘지 않은 코드입니다.

다만 코드 리뷰를 드리면요.

 

계속해서 벡터삭제가 발생 : 이거 O(N)의 시간복잡도가 계속 소모가 됩니다.

      if (i % 2 == 0)
      {
        v.erase(v.begin() + i);
      }

 

이것 말고는 괜찮은 것 같습니다.



또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.


박희천님의 프로필 이미지
박희천
질문자

작은 피드백도 감사합니다. 큰돌님의 방식으로 다시 학습해볼게요!

0

박희천님의 프로필 이미지
박희천
질문자

영상 주행했습니다.

 

위 풀이대로 풀면 입력 사이즈 커지면 바로 짤이겠네요 ㅠㅠ

박희천님의 프로필 이미지
박희천

작성한 질문수

질문하기