inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

1-H

1-H 질문이요

177

Badroutine

작성한 질문수 3

0

http://boj.kr/79ba1593f25043e8bc479c1ec621f4ec

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

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

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

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

p는 쿼리합 배열

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

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

c++ 코딩-테스트

답변 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점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

 

0

Badroutine

감사합니다!

코딩살구클럽

0

10

1

코딩살구클럽 문의

0

25

2

코딩살구클럽 승인

0

28

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

32

2

3-F 채점 관련 질문

0

29

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

32

2

코딩살구클럽 승인

0

41

2

코딩살구클럽승인

0

36

3

코딩살구클럽 승인

0

50

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

45

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

56

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

62

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

64

2

코딩살구클럽 로그인문제

0

78

3

코딩 살구 클럽 로그인 문제

0

84

2

2-J 채점관련 질문

0

65

3

코딩 살구 클럽 Python 지원 가능 여부

0

77

1

살구클럽 아이디 없음 문제

0

76

1

1-O 코딩살구클럽 채점관련 질문

0

60

2

히든 테스트 케이스가 사라졌습니다

0

57

1