인프런 커뮤니티 질문&답변

mhyim님의 프로필 이미지
mhyim

작성한 질문수

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

7-I와 실수형연산의 한계

7-I 문제 37%에서 틀리는데 실수<--> 정수 문제일까요?

해결된 질문

작성

·

49

·

수정됨

0

큰돌님 안녕하세요?

제가 해당 문제 풀면서 아이디어는 맞다고 생각이 되는데

실수로 받는걸 (int)(실수*100) 해서 정수형으로 넣어서 풀려니까 했는데 37%에서 틀려서 질문 들립니다.

 

큰돌님하고 코드 차이가 있다면 scanf왜 cin정도밖에 모르겠습니다.

 

제 코드 어디가 잘못되었는지 조언 주실 수 있을까요?

http://boj.kr/ca02767551c24c84bb23432a91b19f23

 

답변 3

1

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 ㅎㅎ

유태님이 잘 설명하셨는데요 ㅎㅎ

설명하신대로 부동소수점 문제가 맞습니다.

실수연산은 항상 부정확할 때가 있어요 그렇기 때문에 틀릴 수도 있습니다.

이 경우 아주 작은 수를 더하면 해결될 때가 있는데요 ㅎㅎ

		
		cin>>n>>tempm;
		m = (int)(tempm*100 + 0.0005);

이렇게 해보시겠어요?


또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

mhyim님의 프로필 이미지
mhyim
질문자

시간 내서 답변 해주셔서 감사합니다.

0.0005를 더하여 통과하였습니다.

 

히얀한건 0.000000001정도를 더하면 그건 또 37%에서 나가네요

보정의 개념을 이해하여 궁금즘 해결!

 

허허 아직 갈길이 멀은게 실감됩니다.

1

저랑 똑같은 고민을 하시는 분이 계셨네요 ^^ 아래는 제 풀이입니다.

http://boj.kr/d77fb6f86ffa424ebcd6520204738a77

 

추측되는 부분이 있긴 합니다.

 

예전에 6-L 2670번 연속부분최대곱 문제를 누적합의 개념을 응용해서 누적곱으로 풀이했던 적이 있는데요, 테스트케이스는 맞지만 틀렸던 적이 있습니다.

http://boj.kr/2e30d4c294cc4900825bb6f72819449e

 

참 웃긴게, 예를 들어 1.01이라는 실수가 있다면, 컴퓨터는 이걸 1.01이라고 인식하지 않고 1.009999.. 이런 식으로 인식을 합니다. 1.01 * 100 = 101이 아니라, 100.9999.. 가 될 수도 있다는 것이죠!

 

선생님께서 곧 알려주시겠지만, 제 추측은 (int)(1.01 * 100) = 101이 아니라 100으로 인식된 경우가 있을 것 같습니다.

mhyim님의 프로필 이미지
mhyim
질문자

아잇;

실수가 정확하지 않은건 알았어도

소수점의 오차는 작아서 (int)실수 하면 당연히 제가 생각한 정수로 나올 줄 알았는데 제 cs지식 밖인가 보네요;

의견 주셔서 감사합니다 선생님 답변도 같이 확인해봐야겠어요

0

안녕하세요, 인프런 AI 인턴입니다. mhyim님. 질문하신 내용에 대해 확인해보니, “실수형 데이터를 정수로 변환하여 사용하는 과정에서 발생하는 문제”일 가능성이 높아 보입니다.

일반적으로 double이나 float형 값을 int로 변환할 때 주의해야 할 점이 몇 가지 있습니다. 특히 부동 소수점 연산의 특성상 정확도의 손실이 발생할 수 있으므로 조심해야 합니다. 아래 링크를 통해 관련된 해결책을 확인하실 수 있습니다.

유사한 질문과 해결책에 대한 링크:

위의 링크들을 참고하여 실수 변환 및 입출력 방식에 대한 개선점을 찾아보시면 좋겠습니다. 만약 문제 해결에 추가적인 도움이 필요하시다면, 관련 코드 부분을 조금 더 꼼꼼히 살펴보고 질문해 주시면 좀 더 구체적인 지원이 가능할 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

mhyim님의 프로필 이미지
mhyim

작성한 질문수

질문하기