inflearn logo
강의

Course

Instructor

Introduction to Algorithm Problem Solving for IT Employment (with C/C++): Coding Test Preparation

51. Select territory (large: 2D array interval: time limit 1 second: DP)

시간초과가 나요

169

raera2727

4 asked

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;
}

c++ 코딩-테스트

Answer 1

0

communityai8509

안녕하세요, 인프런 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 사용을 권장했습니다.

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

87번 채점 프로그램에 오류가 있는 것 같습니다.

0

85

2

그리디 파트

0

114

2

안녕하세요. 선생님(54번 코드 관련 문의)

0

141

2

테스트 파일 exit_coe_1, time_limit_exceeded 질문

0

142

1

C언어로 코드를 짜면 채점 시에 한 문제 빼고 시간 초과가 발생하는데 해결하는 방법이 있을까요?

0

171

1

19번 질문있습니다

0

121

1

6번 관련 채점오류입니다

0

87

2

22번 문제는 C로 풀어주신 건가요 C++로 풀어주신 건가요?

0

164

2

dev C++ 콘솔창 바로 닫힘

0

245

1

최신화하기

0

170

1

채점이 안되요...

1

260

1

안녕하세요 강사님 정렬에 대해서 설명이 조금 더 듣고 싶습니다.

0

113

1

45번 공주구하기 문제를 list를 이용해서 이렇게 풀어도 될까요?

0

155

1

39번 두 배열 합치기 문제 채점 오류인가 코드 오류인가

0

153

0

채점기에서 틀렸다고 나오는데 이유를 모르겠습니다.

0

148

2

해당 강의에서 C언어로만 진행하는 강의 문의 건

0

143

2

87번 문제 섬나라 아일랜드 질문

0

128

1

16번 문제에서 직접 답을 대입하면 정답이 나오는데 채점에서 wrong answer가 나옵니다.

0

148

1

40번 교집합 문제

0

166

1

43번 뮤직비디오 문제 테스트케이스 4번을 만족 못합니다.

0

168

1

41. 연속된 자연수의 합 문제 질문있습니다.

0

160

1

질문있습니다.

0

187

2

43번 문제 3 ~ 5번에 문제가 있는것 같습니다.

0

243

1

43번 채점결과

0

411

2