해결된 질문
작성
·
115
답변 2
1
안녕하세요 유태님 ㅎㅎ
for(int i = 0; i < s.size(); i++){
int idx = s[i];
if(isVowel(idx))lcnt++, vcnt = 0, is_include_v = 1;
else vcnt++, lcnt = 0;
if(vcnt == 3 || lcnt == 3) flag = 1;
if(i >= 1 && (prev == idx) && (idx != 'e' && idx != 'o')){
이부분에서 i >= 1 다음에 보시면 prev와 현재의 idx를 비교하죠?
이를 기반으로, i = 1일 때 prev의 값은 s[0]입니다. 그러면.. idx 는 s[1]이죠?
만약 i >= 1이 없다면
처음부터... i = 0이기 때문에
prev(s[-1]이지만 할당되지 않아 -1)는 -1이고 -1과 s[0]과 비교하게 되는 것이라 잘못된 값이 나올 수 있습니다.
즉, 이전 요소와 현재 요소를 비교할 때, “이전 요소”가 실제로 존재하는지 확인하기 위한 안전장치 역할을 합니다. 첫 번째 요소에 대해서는 이전 요소가 없기 때문에, 이를 체크하지 않으면 배열의 범위를 벗어나 접근하는 등의 문제가 발생할 수 있습니다.
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
0
안녕하세요, 인프런 AI 인턴입니다.
한유태님의 질문에 대한 답변을 찾기 위해 해당 강좌와 유사한 문제 및 해설을 검토해 보았습니다. 특정 코드 블록의 조건문 i >= 1
의 목적에 대해 궁금해하신 부분이 있으시군요.
유사한 상황에서 이 조건문은 일반적으로 배열, 문자열 또는 시퀀스에서 현재 요소가 첫 번째 요소가 아님을 확인하기 위해 사용됩니다. 이는 prev == idx
와 같은 이전 요소와 현재 요소를 비교할 때, “이전 요소”가 실제로 존재하는지 확인하기 위한 안전장치 역할을 합니다. 첫 번째 요소에 대해서는 이전 요소가 없기 때문에, 이를 체크하지 않으면 배열의 범위를 벗어나 접근하는 등의 문제가 발생할 수 있습니다.
다만, 한유태님께서 말씀하신 것처럼 특정 문제의 경우에 이 조건을 생략해도 정상적으로 정답 처리가 되는 상황이 발생할 수 있는데요, 이는 문제의 조건, 입력값의 범위, 또는 로직의 다른 부분에 의해 영향을 받을 수 있습니다. 조건을 생략해도 문제 없이 작동하는 것은, 해당 문제의 입력값이나 조건 때문에 첫 번째 요소와 관련된 예외 상황이 발생하지 않거나, 다른 부분의 로직에서 이미 이를 충분히 처리하고 있기 때문일 수 있습니다.
이러한 로직의 작성 방식에 대한 추가 설명은 2-H 질문에서 유사한 문의에 답변한 예시를 참고하실 수 있습니다. 질문자님의 경우와 정확히 일치하지 않을 수 있지만, 해당 답변에서는 조건문을 사용하는 이유와 이에 대한 세부 설명이 포함되어 있어 참고하시면 도움이 될 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.