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

상훈님의 프로필 이미지
상훈

작성한 질문수

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

2-S 문제(1325)

작성

·

191

0

define CRTSECURE_NO_WARNINGS

#include <iostream>

#include <vector>

#include <algorithm>

#include <queue>

#include <tuple>

#include <string>

#include <map>

#include <stack>

using namespace std;

vector<int> adj[100001];

int visited[100001];

int n, m, cnt, ret = 1;

int a, b;

void dfs(int node)

{

visited[node] = 1;

for (int i = 0; i < adj[node].size(); i++)

{

if (!visited[adj[node][i]])

{

cnt++;

dfs(adj[node][i]);

}

}

}

int main()

{

ios_base::sync_with_stdio(false);

cin.tie(NULL); cout.tie(NULL);

cin >> n >> m;

for (int i = 0; i < m; i++)

{

cin >> a >> b;

adj[b].push_back(a);

}

for (int i = 1; i <= n; i++)

{

fill(&visited[0], &visited[0] + 100001, 0);

cnt = 0;

dfs(i);

ret = max(ret, cnt);

}

for (int i = 1; i <= n; i++)

{

fill(&visited[0], &visited[0] + 100001, 0);

cnt = 0;

dfs(i);

if (cnt == ret)

cout << i << " ";

}

return 0;

}

 

 

다음과 같이 코드를 작성하였는데 계속 시간초과가 뜨고 인접행렬로 풀면 메모리 초과가 나서 변경하였는데 추가로 어떻게 수정해야될지 모르겠습니다 ㅠㅠㅠ

visual studio에서는 cnt출력 및 i 를 출력했을 때 결과는 맞게 나옵니다

답변 1

0

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

안녕하세요 ㅎㅎ

0주차 : 질문하는 법 참고해서 다시 올려주세요.ㅎㅎ

또한 강의 -링크 : 2 - R 등에서 질문하는 것으로 링크하는 것이요.

부탁드립니다.

 

상훈님의 프로필 이미지
상훈

작성한 질문수

질문하기