해결된 질문
작성
·
27
0
안녕하세요, 큰돌님이 강의에서 설명해주신 코드에서 한가지 사소한 질문이 생겨 글 남기게 됐습니다.
같은 글자가 연속으로 나오면 안되는 조건을 위해서 큰돌님께서 prev를 -1로 초기화 하기 i가 0일 때 제외하고 prev와 현재 idx를 비교해서 같으면 flag = 1 이 되도록 하셨는데요.
처음에 코드를 봤을 때 prev를 s[0]이 아니라 일부러 -1로 두신 이유를 저는 i >= 1 조건을 생략하기 위해서 혹시라도 i가 0 일때의 idx와 prev가 같은 경우가 생기지 않도록 해서 i = 0일 때 조건을 확인해도 어차피 prev == idx가 거짓이 되도록 한걸로 이해했거든요.
(저도 비슷하게 prev를 'a'-1로 초기화하고 for문에서 i=0을 skip하지 않고 다 확인하도록 했습니다. http://boj.kr/8e848001c5b443cd85c5a78d65af69c7)
하지만 강의에서 말씀하신 건 첫번째 i=0일때 비교를 피하기 위해서 i>=1을 넣었다고 하셔서 prev를 s의 첫번째 원소가 아닌 -1을 초기화 하는 부분과 i = 0 일 때 prev와 idx를 비교하는 걸 넘어가는 부분이 상충되는 부분이 있어 질문드렸습니다.
답변 1
0
안녕하세요 예찬님 ㅎㅎ
이부분 말씀하시는거죠?
int prev = -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')){
flag = 1;
}
prev = idx;
}
혹시라도 i가 0 일때의 idx와 prev가 같은 경우가 생기지 않도록 해서 i = 0일 때 조건을 확인해도 어차피 prev == idx가 거짓이 되도록 한걸로 이해했거든요.
-> 네 맞습니다.
하지만 강의에서 말씀하신 건 첫번째 i=0일때 비교를 피하기 위해서 i>=1을 넣었다고 하셔서 prev를 s의 첫번째 원소가 아닌 -1을 초기화 하는 부분과 i = 0 일 때 prev와 idx를 비교하는 걸 넘어가는 부분이 상충되는 부분이 있어 질문드렸습니다.
-> 네 맞습니다. 다만 상충되기보다는 중복되는 코드인 것 같습니다. prev가 어차피 -1로 되어있어서 >=1 부분은 빼도 되서 이렇게 해도 됩니다.
if((prev == idx) && (idx != 'e' && idx != 'o')){
flag = 1;
}
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
항상 친절한 답변 감사드립니다~!!