(四舍五入) AT_abc001C風力観測

AT_abc001C 風力観測

一、题目描述

原题链接

给两个输入,一个是风向,一个是风力,要求以另一种表示形式输出它们。

二、算法分析

总体是一道模拟题,考察了浮点数的四舍五入。

以 5.23 为例,对小数点后第 2 位进行四舍五入,即保留小数点后 1 位。

  1. 将小数点后第 2 位加 5.
  2. 得 5.28
  3. 将小数点移到第 2 位之前的一位。
  4. 得 52.8
  5. 取整。(此处注意加上误差,四舍五入的误差限不超过最后一位的半个单位)
  6. 得 52
  7. 转换为小数。
  8. 得 52.0
  9. 小数点移回去。
  10. 得 5.2

三、代码及注释

cpp 复制代码
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
int a;
double b;
double ad(double x,int p){                //对x的小数点后p位进行四舍五入(即保留小数点后p-1位)
    double eps=0.5*pow(10,p*(-1));        //四舍五入的误差限不超过最后一位的半个单位
    x+=5.0/pow(10,p);                     //先在小数点后第p位加上5
    double w=(int)(x*pow(10,p-1)+eps);    //然后把小数点移到第p位前一位
    double res=w;
    res=res/pow(10,p-1);
    return res;
}
int main(){
    
    cin>>a>>b;
    //计算风向,此时直接用题目给出的整数即可
    string s;
    if(a<=112) s="N";
    else if(a<=337) s="NNE";
    else if(a<=562) s="NE";
    else if(a<=787) s="ENE";
    else if(a<=1012) s="E";
    else if(a<=1237) s="ESE";
    else if(a<=1462) s="SE";
    else if(a<=1687) s="SSE";
    else if(a<=1912) s="S";
    else if(a<=2137) s="SSW";
    else if(a<=2362) s="SW";
    else if(a<=2587) s="WSW";
    else if(a<=2812) s="W";
    else if(a<=3037) s="WNW";
    else if(a<=3262) s="NW";
    else if(a<=3487) s="NNW";     
    else s="N";
    
    //计算风力
    double c=ad((b/60),2);         //题目输入的是每分钟的风程,要转化为每秒的,然后四舍五入
    int d=0;                       //风力等级
    if(c<=0.2) d=0,s="C";
    else if(c<=1.5) d=1;
    else if(c<=3.3) d=2;
    else if(c<=5.4) d=3;
    else if(c<=7.9) d=4;
    else if(c<=10.7) d=5;
    else if(c<=13.8) d=6;
    else if(c<=17.1) d=7;
    else if(c<=20.7) d=8;
    else if(c<=24.4) d=9;
    else if(c<=28.4) d=10;
    else if(c<=32.6) d=11;
    else d=12;
    
    cout<<s<<" "<<d<<endl;
    
    
    
    return 0; 
    
}
相关推荐
JieE21218 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050733 天前
(一)小红的数组操作
算法·编程语言