작성
·
157
·
수정됨
답변 1
0
안녕하세요 현성님 ㅎㅎ
사실 정확히는 다음 코드들과 비교해야 합니다.
while(1){
if(hi == p)break;
else if(sum >= n) sum -= a[lo++];
else sum += a[hi++];
if(sum == n) ret++;
}
이것과
while(1){
if(sum >= n) sum -= a[lo++];
else if(hi == p)break;
else sum += a[hi++];
if(sum == n) ret++;
}
이것인데요.
차이점이 좀 있는데 다음과 같습니다.
hi 가 ++ 한경우 -> hi == p break 가 되어야 하는데
hi 가 ++ 한경우 -> sum을 먼저 체크해서 break가 안되는 경우의 수가
발생합니다.
다만 해당 부분에 대한 반례는 못찾아서 찾으면 다시 답변 드리겠습니다.
감사합니다.