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

Badroutine님의 프로필 이미지
Badroutine

작성한 질문수

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

1-H

1-H 질문이요

작성

·

118

·

수정됨

0

http://boj.kr/79ba1593f25043e8bc479c1ec621f4ec

vscode, dev c++에서는 출력이 잘되는데

백준에서는 계속 런타임에러가 뜨네요

어떤게 문제인지 잘 모르겠습니다

a는 측정한 온도의 배열이고

p는 쿼리합 배열

s는 인접한 k개의 합 배열이고
각각 구한 다음에 s배열의 요소중 최대값을 출력하도록 했습니다.

1. 런타임에러가 왜 뜨는지
2. 강의의 코드에서 psum의 크기가 100001로 선언되어 있는데 psum 배열이 실질적으로 1부터 시작하기 때문에 n이 10만일 경우 psum[100000]을 써야해서 100001로 선언하신게 맞는지 궁금합니다.

답변 1

0

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

안녕하세요 ㅎㅎ

 

런타임에러

>> 잘 짜셨는데요 ㅎㅎ 이렇게만 좀 바꾸시면 됩니다. 주석달아놨어요~~

#include <bits/stdc++.h>
using namespace std;

int n, k;

int main() {
    cin >> n >> k;
    vector<int> a(n);
    vector<int> p(n);
    vector<int> s(n - k + 1); 
    
    for (int i = 0; i < n; i++) {
        cin >> a[i];
    }
    
    p[0] = a[0];
    for (int i = 1; i < n; i++) {
        p[i] = p[i - 1] + a[i];
    }
    
    s[0] = p[k - 1];
    for (int i = 1; i <= n - k; i++) { // 인덱스 범위 수정
        s[i] = p[i + k - 1] - p[i - 1];
    }
    
    cout << *max_element(s.begin(), s.end());
    
    return 0;
}

 

강의의 코드에서 psum의 크기가 100001로 선언되어 있는데 psum 배열이 실질적으로 1부터 시작하기 때문에 n이 10만일 경우 psum[100000]을 써야해서 100001로 선언하신게 맞는지 궁금합니다.

>> 네 맞습니다. ㅎㅎ 그리구 이부분은 교안내의 다음부분도 참고부탁드립니다.

 

image

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

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

감사합니다.

강사 큰돌 올림.

 

Badroutine님의 프로필 이미지
Badroutine
질문자

감사합니다!

Badroutine님의 프로필 이미지
Badroutine

작성한 질문수

질문하기