1-H index가 0일 때
217
작성한 질문수 10
#include <bits/stdc++.h>
using namespace std;
int n, k, temp, psum[100001], ret = -987654321;
int main(){
ios_base::sync_with_stdio(false);
cout.tie(0);
cin.tie(0);
cin >> n >> k;
for(int i=1;i<=n;i++){
cin >> temp; psum[i] = psum[i-1] + temp;
}
for(int i=k;i<=n;i++){
ret = max(ret, psum[i] - psum[i-k]);
}
cout << ret <<endl;
return 0;
}
코드 전체를 가져 왔습니다.
i가 순회할 때, 1부터 시작하지만 그렇게 되면 psum[1] = psum[0] - temp가 되는데 이는 0번째가 초기화되지도 않았는데 참조하게 됩니다. 그렇다고 psum[0]이 0은 아니니까요.
그리고
ret = max(ret, psum[i] - psum[i-k]); 에서 k가 5일 때, psum[5] - psum[0]가 되는데
psum[4]도 빼지 않고 후보군에 포함되어야 하는데 모든 범위를 순회했다고 볼 수 없습니다.
그래서 저는 treadmill 구조를 떠올려서 만들었습니다.
제가 지적한 오류가 맞는지 글을 남기는 겁니다.
#include <bits/stdc++.h>
using namespace std;
int main(){
ios_base::sync_with_stdio(false);
cout.tie(0);
cin.tie(0);
int n, k, tmp;
cin >> n >> k;
vector<int> v1(n,0);
for(int i=0;i<n;i++){
cin >> tmp;
v1[i]=tmp;
}
tmp =0;
for(int i=0;i<k;i++){
tmp += v1[i];
}
//미세섬유에서 treadmill model를 모사한 two pointer
int tmp2= tmp;
for(int i=0;i<n-(k);i++){
tmp -= v1[i];
tmp += v1[i+k];
if(tmp2 < tmp) tmp2 =tmp;
}
cout << tmp2;
return 0;
}
답변 1
0
안녕하세요. RokiePlayer님ㅎㅎ
그렇게 되면 psum[1] = psum[0] - temp가 되는데 이는 0번째가 초기화되지도 않았는데 참조하게 됩니다. 그렇다고 psum[0]이 0은 아니니까요.
>> C++에서 전역변수로 초기화 하면 어떤값이 할당이 되나요? 0입니다. psum은 전역변수로 어떠한 값을 할당하지 않았죠? 이경우 bss세그먼트에 할당이 되며 0으로 초기화 하면서 들어갑니다. 이 내용은 교안에 다 있습니다. 교안을 다시 한번 봐주세요 ㅎㅎ
ret = max(ret, psum[i] - psum[i-k]); 에서 k가 5일 때, psum[5] - psum[0]가 되는데
psum[4]도 빼지 않고 후보군에 포함되어야 하는데 모든 범위를 순회했다고 볼 수 없습니다.
>> 요소가 1인덱스부터 있으며 1, 2, 3, 4, 5에 해당하는 값들이 다 들어갑니다.
또 질문사항있으시면 언제든 말씀 부탁드립니다.
감사합니다.
강사 큰돌 올림.
0
이해했습니다.
저는 0부터 누적합을 0-4까지 이렇게 더하고 뒤를 없애는 방식으로 했는데
여기는 psum[0] ==0이군요.
이렇게 하면 굳이 첫째 대입을 안 해도 되니까요.
1-E질문입니다!
0
517
2
3-L 틀린 부분 피드백 부탁드립니다.
0
819
2
1-A문제 순열재귀함수 질문입니다.
0
381
1
1-A 일곱난쟁이문제입니다
0
455
1
문제 풀 때 방향성에 대해
0
798
1
맥에서 vs code로 실행 관련 질문입니다
0
522
1
17071번 메모리 초과
0
386
1
1-C질문입니다!
0
418
2
2-B BFS 시간초과질문
0
629
2
1-O 13번 라인
0
441
1
6-J 놀이공원 문제 질문
0
381
1
구현관련 질문
0
482
1
강의 교안
0
319
1
실력을 더 올리고나서 강의를 보는 것이 맞을까요?
0
545
1
안녕하세요! 재귀함수에 관해서 질문드립니다
0
535
1
1-K
0
473
2
3-G번 질문있습니다.
1
473
3
3-C 실행 시간 질문드립니다.
0
493
1
4-A 문제 풀이 질문있습니다.
0
590
2
비트마스킹 연산자 "1의 보수" 영문 표기법
0
435
1
격자탐색 문제에서 BFS 시간복잡도 질문드립니다.
0
334
1
3-O go 함수 질문 드립니다.
1
446
2
4-A 출력 질문
0
303
1
1주차 1-O 질문드립니다
0
255
1





