Why C# compares "the same" floating numbers in C# different [duplicate] - c#

This question already has answers here:
Is floating point math broken?
(31 answers)
Modulus gives wrong outcome?
(1 answer)
Closed 4 years ago.
float a = 0.95f;
float b = 5.05f;
float ab = (a + b);
bool isTrue = (ab == 6.0f);
bool isFalse = ((a + b) == 6.0f);
bool isTrueAgain = ((float)(a + b) == 6.0f);
Why isTrue is true?
Why isFalse is false?

Related

Dividing results in zero for some reason? [duplicate]

This question already has answers here:
Why does integer division in C# return an integer and not a float?
(8 answers)
Division returns zero
(8 answers)
Closed 2 years ago.
I was doing a data science pet project, this is a simplified version of the problem:
int b = 102;
int c = 248;
double a = (b / c) * 100;
Console.WriteLine(a); // prints 0
This code prints zero for some reason. Any other alternatives? Why is this happening?
Because "b / c" is zero, you should use:
int b = 102;
int c = 248;
double a = ((double)b / c) * 100;
int k = Convert.ToInt32(a);
Console.WriteLine(k);

How to check my double variable is an integer or not? [duplicate]

This question already has answers here:
How to determine if a decimal/double is an integer?
(17 answers)
Get the decimal part from a double
(18 answers)
Closed 4 years ago.
I have a variable from:
double result = myList.Count / mySeptum;
I want to do the following:
if( result == int ) {
//Do Something...
}
else{
//Do another thing...
}
How can I do this?
I also tried this, but it didn't work:
if ( result%10 == 0 ){
...
}
In an example:
private void button2_Click(object sender, EventArgs e)
{
int r = 10;
int l = 2;
double d = r / l;
if (d % 10 == 0)
{
Console.WriteLine("INTEGER");
}
else
{
Console.WriteLine("DOUBLE");
}
}
For example:
double d = 1.0;
bool isInt = d == (int)d;
modulo:
double d = 1.0;
bool isInt = d % 1 == 0;
In general a floating point number on a computer can not represent every real number but only some discrete values. Thus, only for a few integers it will be possible that a double can be mathematically identical to an integer value. For most integers the closest double will be off by a small amount. So if you are looking for exact matches this will not work.
However, what you could do is to convert your double into an integer an check if the difference between the double and the integer is small enough:
double d = 1.5;
int i = (int) d;
double diff = d - i;
if (diff < 1.0e-6)
{
std::cout << "number is close to integer" << std::endl;
}
How to check my double variable is an integer or not?
From a C point of view (as post was originally tagged):
(I am certain C# has equivalent functions.)
To determine if a double is a whole number, use modf() to return the fractional part.
#include <math.h>
double x = ....;
double ipart;
if (isfinite(x) && modf(x, &ipart) == 0.0) {
// value is a whole number
....
To further test if it is in int range
if (ipart >= INT_MIN && ipart <= INT_MAX) {
int i = (int) ipart;
To check for wider integer types, we need some trickery to insure to no round-off error when forming the limits. Code takes advantage that INT..._MAX are Mersenne numbers
#define INT64_MAX_P1 ((INT64_MAX/2 + 1)*2.0)
if (ipart >= INT64_MIN && ipart < INT64_MAX_P1) {
int64_t i64 = (int64_t) ipart;
Try with typeOf:
if (myInt.GetType() == typeof(int))

Change Integer value to Roundoff by the nearest integer [duplicate]

This question already has answers here:
How to round up value C# to the nearest integer?
(10 answers)
Closed 6 years ago.
int a = 4;
int b = 3;
int c = a/b;
Here the c value as 1.33 . now i need to change the value as whole number like 2.
If,
int a =1;
int b = 2;
int c = a/b means the value is 0.5
now i need to change the value as next whole number like 1
Please try this:
int a = 4;
int b = 3;
int c = Convert.ToInt32(Math.Ceiling(a/b));

Swap two integers without using a third variable for all range of integer values [duplicate]

This question already has answers here:
Swap two variables without using a temporary variable
(29 answers)
Closed 8 years ago.
How to swap 2 integers without using a third variable such that it works for all ranges of integers.
I know that generally we do the following logic.
int a, b;
a = 10;
b = 30;
a = a + b;
b = a - b;
a = a - b;
But this logic will fail if (a + b) gives the value more than the integer range.
Is there any other logic?
I believe you're looking for the XOR swap:
if (a != b) {
a ^= b;
b ^= a;
a ^= b;
}
You can use xor ...
x ^= y;
y ^= x;
x ^= y;
Source with a handy live demo.
int a=10;
int b=20;
a=a^b;
b=a^b;
a=a^b;
Console.WriteLine(a);
Console.WriteLine(b);

Making a double division [duplicate]

This question already has answers here:
What is the best practice to make division return double in C#
(6 answers)
Closed 8 years ago.
I'm trying to make a double divion with this code:
int a = 5;
int b = 5;
double result = (a + b) / 4;
How to get a 2.5 as a result and not 2, please?
Thanks in advance!
One of the arguments needs to be a double. So:
double result = (a + b) / 4.0;
Or
double result = (double)(a + b) / 4;

Categories

Resources