if문의 condition부분에다가 함수의 return값을 받으면 안되나요?(c++)
글쓴이: hep93 / 작성시간: 금, 2016/03/25 - 5:25오후
tmp3 = tmp; while(true){ tmp2 = tmp; tmp = bigSum(tmp, tmp3); cout << "a :"; print_bigNum(a); cout << ", tmp :"; print_bigNum(tmp); // cout << ", " << abscmp(a, tmp); cout << endl; if(abscmp(a, tmp)){ div2 = bigSum(div2, one); } else{ tmp = tmp2; break; } }
tmp를 일정하게 늘려나가면서 a보다 같거나 작은 최대의 tmp를 찾는 코드인데요
디버그하려고 표준출력으로 변수값을 출력해보니
... a :80, tmp :60 a :80, tmp :70 a :80, tmp :80 Program ended with exit code: 0
이런식으로 나오는데 원래는 tmp가 70 -> 80 -> 90 -> 80 이렇게 끝나야 되거든요
그래서 위 코드에서 주석처리한부분을 주석없애고 실행시키니까
a :80, tmp :50, 1 a :80, tmp :60, 1 a :80, tmp :70, 1 a :80, tmp :80, 1 a :80, tmp :90, 0 Program ended with exit code: 0
이렇게 정상적으로 나와요... abscmp을 앞에서 실행시켰을 뿐인데 도대체 왜 결과가 다른거죠?
abscmp은 확실히 true나 false를 반환하도록 되어있는데요
bool abscmp(bigNum a, bigNum b){ int c = MAX_DIGIT-1; while(a.n[geshifilter-c] == b.n[c]) { c--; } if(a.n[c] >= b.n[c]) return true; else return false; }
Forums:
bigNum이 어떻게 생긴 구조인지는 모르겠는데, 두
bigNum이 어떻게 생긴 구조인지는 모르겠는데, 두 수가 같다면 a.n와 b.n은 아마도 완전히 같겠죠?
그러면 abscmp의 while루프는 언제 끝날까요? c가 유효한 값(0 이상)인 한 절대로 안끝나겠죠?
그러면 c가 0을 넘어 음수로 치달을 거고 프로그램은 이상한 데를 참조하게 되지 않을까요?
while(a.n[geshifilter-c] == b.n[c])
를while(c > 0 && a.n[c] == b.n[c])
으로 고쳐보세요. 이게 문제를 해결해드릴 거라고 장담은 못 하겠습니다. 어쨌든 틀린 건 고쳐야죠.[/geshifilter-c]고치니까 해결됐어요 ㅠㅠ 감사합니다
고치니까 해결됐어요 ㅠㅠ 감사합니다
고치니까 해결됐어요 ㅠㅠ 감사합니다
고치니까 해결됐어요 ㅠㅠ 감사합니다
댓글 달기