Written on
·
36
1
- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
%연산은 근데 int만 되나요?
int main()
{
int n, m;
n = 3;
m = 4;
float a = 3.0;
float b = 7.0;
cout << a % b << endl;
cout << (float)m%n<< endl;
cout << m % n << endl;
cout << m%(float)n << endl;
}
이런식으로 찍어봤는데 다 오류가 나더라고요.
왜 float는 안되는걸까요?
Answer 2
1
안녕하세요? 질문&답변 도우미 Soobak 입니다.
네, %
연산자는 정수형 데이터 타입에만 사용할 수 있습니다. (short
, int
, long
, long long
, unsgined short
등)
강의 2.6 부동소수점수 floating point numbers 에서 학습하신 내용처럼,
부동소수점 숫자는 '근사값' 으로 표현되므로 정확한 나머지를 계산하기 어렵기 때문에 %
연산을 지원하지 않습니다.
다만, <cmath>
와 같은 표준 라이브러리에 포함되어 있는 fmod()
함수 등으로 부동소수점수에 대한 나머지도 편리하게 구하실 수 있습니다.
혹은 다음과 같이 수동으로 계산할 수도 있습니다.
float remainder = a - b * floor(a / b);
cout << remainder << endl;
하지만, 이러한 방법들도 부동소수점수의 근본적인 '근사적 표현' 으로 오차가 발생할 수 있다는 점을 염두해두시는 것이 학습에 도움이 되실 것 같습니다.
0
안녕하세요, 인프런 AI 인턴입니다.
김성관님의 질문에 대한 답변으로, C++ 프로그래밍 언어에서 %
연산자는 나머지 연산(모듈로 연산)을 수행하는 데 사용되며, 이 연산자는 정수형(integers)에 대해서만 사용이 가능합니다. 따라서, float
나 double
과 같은 부동 소수점 타입에 %
연산자를 사용하려고 할 때 컴파일 오류가 발생하는 것입니다. 부동 소수점 수에 대한 나머지 연산을 하고자 할 때는 표준 라이브러리 함수인 fmod
함수를 사용할 수 있습니다. 예를 들어, fmod(a, b)
는 a
를 b
로 나눈 나머지를 반환합니다.
질문과 관련된 보충 자료로, 이전에 유사한 질문에 대한 답변을 드린 바 있으니 참고하시기 바랍니다:
%
연산자의 사용에 대한 것은 아니지만, C++ 프로그래밍 기초와 관련된 내용을 담고 있어 유용할 수 있습니다.부동 소수점 수에 대한 나머지 연산에 대한 구체적인 예시는 다음과 같습니다:
#include <iostream>
#include <cmath> // fmod 함수를 사용하기 위해 필요
int main() {
float a = 3.0;
float b = 7.0;
// float 형에 대한 나머지 연산
std::cout << "fmod(a, b): " << fmod(a, b) << std::endl;
return 0;
}
이 답변이 김성관님의 질문에 대해 도움이 되길 바랍니다. %
연산자는 정수형에만 유효함을 기억하시고, 부동 소수점 수에 대한 나머지를 구하고자 할 때는 fmod
함수를 사용해 보세요.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.