Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Prodentim Probiotics Specially Designed For The Health Of Your Teeth And Gums

Instant Grammar Checker - Correct all grammar errors and enhance your writing

Teach Your Child To Read

Powerful WordPress hosting for WordPress professionals

Disclosure: My content contains affiliate links.

31,038 questions

40,794 answers

573 users

How to use nearbyint() function to round floating-point to integer in floating-point format in C++

Learn & Practice SQL


86 views
asked Mar 27, 2016 by avibootz
edited Mar 27, 2016 by avibootz

1 Answer

0 votes
#include <iostream>
#include <cmath>
#include <cfenv>

using namespace std;

int main()
{
	fesetround(FE_TONEAREST);
	cout << "rounding to nearest :" << endl;
	cout << "nearbyint(3.3) = " << nearbyint(3.3) << endl;
	cout << "nearbyint(3.5) = " << nearbyint(3.5) << endl;
	cout << "nearbyint(4.5) = " << nearbyint(4.5) << endl;
	cout << "nearbyint(4.6) = " << nearbyint(4.6) << endl;
	cout << "nearbyint(-3.3) = " << nearbyint(-3.3) << endl;
	cout << "nearbyint(-3.5) = " << nearbyint(-3.5) << endl;
	cout << "nearbyint(-4.5) = " << nearbyint(-4.5) << endl;
	cout << "nearbyint(-4.6) = " << nearbyint(-4.6) << endl << endl;

	fesetround(FE_DOWNWARD);
	cout << "rounding down: " << endl;
	cout << "nearbyint(3.3) = " << nearbyint(3.3) << endl;
	cout << "nearbyint(3.5) = " << nearbyint(3.5) << endl;
	cout << "nearbyint(4.5) = " << nearbyint(4.5) << endl;
	cout << "nearbyint(4.6) = " << nearbyint(4.6) << endl;
	cout << "nearbyint(-3.3) = " << nearbyint(-3.3) << endl;
	cout << "nearbyint(-3.5) = " << nearbyint(-3.5) << endl;
	cout << "nearbyint(-4.5) = " << nearbyint(-4.5) << endl;
	cout << "nearbyint(-4.6) = " << nearbyint(-4.6) << endl << endl;;

	fesetround(FE_UPWARD);
	cout << "rounding up: " << endl;
	cout << "nearbyint(3.3) = " << nearbyint(3.3) << endl;
	cout << "nearbyint(3.5) = " << nearbyint(3.5) << endl;
	cout << "nearbyint(4.5) = " << nearbyint(4.5) << endl;
	cout << "nearbyint(4.6) = " << nearbyint(4.6) << endl;
	cout << "nearbyint(-3.3) = " << nearbyint(-3.3) << endl;
	cout << "nearbyint(-3.5) = " << nearbyint(-3.5) << endl;
	cout << "nearbyint(-4.5) = " << nearbyint(-4.5) << endl;
	cout << "nearbyint(-4.6) = " << nearbyint(-4.6) << endl << endl;

	fesetround(FE_TOWARDZERO);
	cout << "rounding toward zero: " << endl;
	cout << "nearbyint(3.3) = " << nearbyint(3.3) << endl;
	cout << "nearbyint(3.5) = " << nearbyint(3.5) << endl;
	cout << "nearbyint(4.5) = " << nearbyint(4.5) << endl;
	cout << "nearbyint(4.6) = " << nearbyint(4.6) << endl;
	cout << "nearbyint(-3.3) = " << nearbyint(-3.3) << endl;
	cout << "nearbyint(-3.5) = " << nearbyint(-3.5) << endl;
	cout << "nearbyint(-4.5) = " << nearbyint(-4.5) << endl;
	cout << "nearbyint(-4.6) = " << nearbyint(-4.6) << endl;

	return 0;

}

/*
run:

rounding to nearest :
nearbyint(3.3) = 3
nearbyint(3.5) = 4
nearbyint(4.5) = 4
nearbyint(4.6) = 5
nearbyint(-3.3) = -3
nearbyint(-3.5) = -4
nearbyint(-4.5) = -4
nearbyint(-4.6) = -5

rounding down:
nearbyint(3.3) = 3
nearbyint(3.5) = 3
nearbyint(4.5) = 4
nearbyint(4.6) = 4
nearbyint(-3.3) = -4
nearbyint(-3.5) = -4
nearbyint(-4.5) = -5
nearbyint(-4.6) = -5

rounding up:
nearbyint(3.3) = 4
nearbyint(3.5) = 4
nearbyint(4.5) = 5
nearbyint(4.6) = 5
nearbyint(-3.3) = -3
nearbyint(-3.5) = -3
nearbyint(-4.5) = -4
nearbyint(-4.6) = -4

rounding toward zero:
nearbyint(3.3) = 3
nearbyint(3.5) = 3
nearbyint(4.5) = 4
nearbyint(4.6) = 4
nearbyint(-3.3) = -3
nearbyint(-3.5) = -3
nearbyint(-4.5) = -4
nearbyint(-4.6) = -4

*/

 





answered Mar 27, 2016 by avibootz
...