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

성우님의 프로필 이미지
성우

작성한 질문수

it 취업을 위한 알고리즘 문제풀이 입문 (with C/C++) : 코딩테스트 대비

51. 영지 (territory) 선택 (large : 2차원 배열 구간합 : 제한시간 1초 : DP)

시간초과가 나요

작성

·

104

0

선생님 강의 설명 듣고 저 혼자서 구현해봤는데 구현한 방법은 비슷한 것 같은데 채점돌려보니까 마지막 문제가 시간초과가 걸리네요... 어디가 문제인걸까요? 문제에 대한 정답은 제대로 나오네요.

#include <bits/stdc++.h>
using namespace std;
const int INF = 1e9;

int a[704][704], d[704][704], n, m, ret, w, h;

int cal(int x, int y)
{
	return d[x][y] - (d[x - h][y] + d[x][y - w] - d[x - h][y - w]);
}

int main()
{
	ios_base::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);

	cin >> n >> m;

	for (int i = 1; i <= n; i++)
	{
		for (int j = 1; j <= m; j++)
		{
			cin >> a[i][j];
			d[i][j] = d[i - 1][j] + d[i][j - 1] - d[i - 1][j - 1] + a[i][j];
		}
	}

	cin >> h >> w;

	for (int i = h; i <=n; i++)
	{
		for (int j = w; j <= m; j++)
		{
			ret = max(ret, cal(i, j));
		}
	}

	cout << ret;
	return 0;
}

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. 성우님, 공유해 주신 소스 코드와 문제 상황을 꼼꼼히 살펴보았습니다. 주신 코드는 강의 내용을 기반으로 구현하신 것 같습니다. 지정된 부분에 대해 시간 초과 문제를 해결하기 위해 유사한 상황에서의 조언을 찾았습니다.

시간 초과 문제는 주로 알고리즘이 데이터를 처리하는 과정에서 비효율적으로 동작하기 때문에 발생합니다. 성우님께서 공유하신 코드는 ‘2차원 누적 합’ 문제의 해결법으로 보이며, 효율적으로 구현된 것처럼 보입니다. ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); 설정도 입출력 속도 향상을 위한 좋은 접근입니다.

하나의 가능한 문제 해결 방안으로, 성우님의 질문을 직접적으로 해결할 수 있는 구체적인 예시는 제가 찾은 51번 문제 5번에서 타임 리미트 발생 이슈와 비슷합니다. 해당 질문에서 핵심 포인트는 ios_base::sync_with_stdio(false); 사용과 함께 효율적인 알고리즘 구현에 있었습니다. 특히, cincout 대신 scanfprintf를 사용한 경우 더 빠른 입출력을 달성할 수 있는 경우가 있으나, 이미 성우님은 ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);를 사용하여 최적화를 시도하셨으므로, 알고리즘 로직 자체에서의 최적화 여지를 다시 한번 확인해볼 필요가 있습니다.

성우님의 코드와 비슷한 문제를 겪은 다른 학습자에게 시간 초과 문제를 극복하는 데 도움이 될 수 있는 입출력 속도 관련 조언을 한 경우의 링크입니다:

  • 51번 문제 5번 Time_limted
    • 답변에서는 ios_base::sync_with_stdio(false); 추가하고, 입력량이 많은 경우 cin, cout 대신 scanf, printf 사용을 권장했습니다.

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

성우님의 프로필 이미지
성우

작성한 질문수

질문하기