square of a float number in C
-
12-03-2021 - |
Question
I have written a code in C which works fine for int but when I try to do this with float it is showing error what can i do to make it correct.
#include<stdio.h>
int main()
{
float a,y;
float square();
scanf("%f", &a);
y = square( a );
printf("%f %f ",a ,y);
}
float square(float b)
{
float z;
z = b*b;
printf("%f %f",z ,b);
return(z);
}
error:
return.c:12: error: conflicting types for 'square'
return.c:13: note: an argument type that has a default promotion can't match an empty parameter name list declaration
return.c:6: note: previous declaration of 'square' was here
Solution
Move the declaration of square()
out of the function and make sure the prototype matches:
float square(float b); // Make sure this matches the definition.
int main()
{
float a,y;
scanf("%f", &a);
y = square( a );
printf("%f %f ",a ,y);
}
float square(float b)
{
float z;
z = b*b;
printf("%f %f",z ,b);
return(z);
}
As for why it "worked" for int
, you'll have to show us the exact code you used for that case.
OTHER TIPS
You're just missing the argument in the prototype you gave. You had
float square();
When it should be
float square(float);
You don't need to move it outside the function, but you do need to make sure the prototype has the same signature (return type, name, and parameter count/types) as the function that you define later.
Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow