inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

6-H

6-H 맵 관련 질문있습니다 :)

해결된 질문

80

한유태

작성한 질문수 79

0

안녕하세요 선생님 🙂

 

시간복잡도가 굉장히 타이트해서 이분탐색으로 푸는 문제인 것은 알고 있으나, 테스트 겸 map으로 다시 풀어보다가 이해가 되지 않는 부분이 있어서 질문드립니다.

 

30번째 줄의 mp[vecA[i]]++; 이 부분때문에 틀리는건데요, mp[vecA[i]] = 1;이라고 하면 맞더라구요. 둘이 연산 차이가 없어보이고, 테스트케이스도 정상적으로 출력이 되는데요, 제가 놓치고 있는 부분이 있을까요?

 

http://boj.kr/076e9301948a40c9afb2262e5e4c26c0

c++ 코딩-테스트

답변 2

0

큰돌

안녕하세요 유태님 ㅎㅎ

++를 했으면 거기에 맞춰서 로직을 수정해야 합니다.

/*
	1.
*/

#include <iostream>
#include <vector>
#include <unordered_map>

using namespace std;

int T, N, M;
int temp;
unordered_map<int, int> mp;

int main()
{
	ios::sync_with_stdio(false);
	cin.tie(NULL); cout.tie(NULL);

	cin >> T;
	for (int i = 0; i < T; i++)
	{
		mp.clear();

		cin >> N;
		vector<int> vecA(N);
		for (int i = 0; i < N; i++)
		{
			cin >> vecA[i];
			mp[vecA[i]]++;
		}
		cin >> M;
		vector<int> vecB(N);
		for (int i = 0; i < M; i++)
		{
			cin >> vecB[i];

			if (mp[vecB[i]] >= 1) cout << 1 << '\n';
			else cout << 0 << '\n';
		}
	}

	return 0;
}

이렇게 해보시겠어요?

 

또한 이부분은 교안내의 다음 부분 참고도 부탁드립니다.

image.png

 

 

 


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

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

감사합니다.

강사 큰돌 올림.


0

한유태

혹시 내부 테스트케이스 중에 4 1 5 2 3과 같이 다른 숫자들만 있는게 아니라 다른 숫자들도 있기 때문에 mp[vecB[i]] >= 1와 같이 조건을 세우는 것일까요?

1

큰돌

네 맞습니다.

4 4 이렇게 나올 가능성도 고려했습니다.

 

0

한유태

반례가 너무 머리아프네요 ㅠㅠ 감사합니다!!

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 한유태님.

C++에서 map을 사용하여 카운팅하는 로직에서 mp[vecA[i]]++;mp[vecA[i]] = 1; 사이의 차이를 이해하는 것은 중요합니다. 먼저, mp[vecA[i]]++;vecA[i]의 값을 키로 하는 항목이 존재하지 않을 경우 해당 키를 생성하고, 이후 값이 0으로 초기화된 후 증가시키는 방식입니다. 이는 C++에서 map의 기본 동작으로, 존재하지 않는 키를 참조하면 자동으로 디폴트 생성(0으로 초기화)합니다.

그러나 mp[vecA[i]] = 1;의 경우는 키 vecA[i]의 값을 1로 설정하기 때문에, 초기화를 명시적으로 처리하고 있습니다. 따라서 만약 vecA[i]가 초기화되지 않은 상태라면, mp[vecA[i]]++;은 기본적으로 1이 아닌 0부터 시작하여 1이 증가된 상태로 등록되므로 차이가 발생할 수 있습니다.

관련하여 유사한 질문 및 답변을 참고하시면 도움이 될 것입니다:

  • 6-E 해당문제 이분탐색은 솔루션은 어떨까요?
    • 질문 요약: map 대신 다른 방법을 사용하여 시간/공간 복잡도를 개선할 수 있는지.
    • 답변 요약: 이분 탐색을 사용하는 것은 특정 문제에서 적합한 접근이며, map을 사용한 방식과의 차이점 분석.

이와 같이 특정 자료구조를 사용할 때 각 연산의 세부적 차이를 이해하고, 문제의 요구사항에 맞게 코드가 제대로 작동하는지 확인하는 것이 중요합니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

교안 158페이지 문의드립니다

0

9

2

코딩살구클럽 관련 건의사항

0

23

1

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

11

1

진행 방법 질문드립니다!

0

42

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

169

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