据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。真实体重与标准体重误差在10%以内都是完美身材(即 | 真实体重 − 标准体重 | < 标准体重×10%)。已知市斤是公斤的两倍。现给定一群人的身高和实际体重,请你告诉他们是否太胖或太瘦了。
输入格式:
输入第一行给出一个正整数N
(≤ 20)。随后N
行,每行给出两个整数,分别是一个人的身高H
(120 < H < 200;单位:厘米)和真实体重W
(50 < W ≤ 300;单位:市斤),其间以空格分隔。
输出格式:
为每个人输出一行结论:如果是完美身材,输出You are wan mei!
;如果太胖了,输出You are tai pang le!
;否则输出You are tai shou le!
。
输入样例:
3
169 136
150 81
178 155
输出样例:
You are wan mei!
You are tai shou le!
You are tai pang le!
开始这题 看似简单,如果只用abs取绝对值只取到整数,分拿不完,需要用到fabs。
两个函数头文件都是cmath(针对c++)C语言据说源自stdio.h
fabs函数是取绝对值可以取浮点数的绝对值,因为这题涉及除法,可能出现浮点数。
但我实践中发现abs可以输出浮点数
例如:cout<<abs(-3.1415) 和 cout<<abs(-3.5555)都能输出浮点数绝对值
所以主要还是看你定义的变量类型了
附上我的代码
#include<iostream>
#include<cstring>
#include<math.h>
#include<cstdio>
using namespace std;
int txt,l;
string A,B;
int N,H,W;
int main()
{
cin>>N;
float F[N];
int H[N],W[N];
for(int i=1;i<=N;i++)
{
cin>>H[i]>>W[i];
F[i] = (H[i] - 100) * 0.9;
F[i] *= 2.0;
}
for(int i=1;i<=N;i++)
{
float gg = fabs(F[i]-W[i]);
float kk = F[i]*0.1;
if(W[i]>F[i]&& gg >= kk)cout<<"You are tai pang le!"<<endl;
if(W[i]<F[i]&& gg >= kk)cout<<"You are tai shou le!"<<endl;
if( gg != kk && gg < kk)cout<<"You are wan mei!"<<endl;
}
return 0;
}