what is the output, explain it plz
#include <stdio.h>
int main()
{
int a=2;
float b=4.0;
printf("%d %f",a/b,a/b);
printf("%f %d",a/b,a/b);
}
c question
c question
everyone here are best programmers ( not yet not yet)
- JackScott
- Member
- Posts: 1032
- Joined: Thu Dec 21, 2006 3:03 am
- Location: Hobart, Australia
- Mastodon: https://aus.social/@jackscottau
- GitHub: https://github.com/JackScottAU
- Contact:
Why don't you just try the output and see?
It should all be one line, with two decimal numbers and two floats. The floats will be in the middle. The first number, being a decimal, will either round up or down (I don't have a compiler on me, but I'm guessing down), because 0.5 can't be output as an integer.
Help you?
It should all be one line, with two decimal numbers and two floats. The floats will be in the middle. The first number, being a decimal, will either round up or down (I don't have a compiler on me, but I'm guessing down), because 0.5 can't be output as an integer.
Help you?
Re: c question
a/b is int divided by float. The result is therefore a float. That is cast to a double because printf doesn't specify the exact argument type (C language exception). It happens for both. In the first line, %d picks the first 32 bits and displays them (which is bull), %f picks the next 64 bits which is halfway between a number, also bull. The second line first prints %f, the first 64 bits, which will be the result, the %d will print the same bull as the line before for %d.pulsar wrote:what is the output, explain it plz
#include <stdio.h>
int main()
{
int a=2;
float b=4.0;
printf("%d %f",a/b,a/b);
printf("%f %d",a/b,a/b);
}
Try printf("%d %d %f", a/b, a/b); and ignore the compiler warning (if applicable). That displays two bits of bull (each 32-bit) and one real number.