专家通过多组情侣研究数据发现,最佳的情侣身高差遵循着一个公式:(女方的身高)×1.09 =(男方的身高)。如果符合,你俩的身高差不管是牵手、拥抱、接吻,都是最和谐的差度。
下面就请你写个程序,为任意一位用户计算他/她的情侣的最佳身高。
输入格式:
输入第一行给出正整数N(≤10),为前来查询的用户数。随后N行,每行按照“性别 身高”的格式给出前来查询的用户的性别和身高,其中“性别”为“F”表示女性、“M”表示男性;“身高”为区间 [1.0, 3.0] 之间的实数。
输出格式:
对每一个查询,在一行中为该用户计算出其情侣的最佳身高,保留小数点后2位。
输入样例:
2
M 1.75
F 1.8
输出样例:
1.61
1.96
//本题我们就是根基输入的字母判断是男生还是女生然后对其要找到的情侣进行身高计算(M男F女)
#include<stdio.h>
//这里我们创建两个函数用来计算完美的情侣身高(因为返回的身高为浮点型,所以我们把函数定义为double类型)
double boy(double h)
{
h/=1.09;//男->女
return h;
}
double girl(double h)
{
h*=1.09;女->男
return h;
}
int main()
{
int n=0;
scanf("%d",&n);
double h=0;
char ch=0;
double perfect[10];//因为是同意输出所以我们定义一个数组用来存放完美匹配的身高
for(int i=0;i<n;i++)
{
scanf(" %c%lf",&ch,&h);//重点:因为在读取%c时会面会自动多读取一个\n导致我们输入的次数会发生改变所以再%c前面加上一个空格来消去后面的\n。
if(ch=='M')
{
perfect[i]=boy(h);
}
if(ch=='F')
{
perfect[i]=girl(h);
}
}
for(int i=0;i<n;i++)
{
printf("%.2lf\n",perfect[i]);
}
return 0;
}
注意:本题我们值得注意的就是消去scanf在读取%c时后面会自动添加一个\n,因此我们要消去。
关于scanf与%c可以参考此篇文章