(四舍五入) 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; 
    
}
相关推荐
cynicme1 小时前
力扣3228——将 1 移动到末尾的最大操作次数
算法·leetcode
熬了夜的程序员1 小时前
【LeetCode】109. 有序链表转换二叉搜索树
数据结构·算法·leetcode·链表·职场和发展·深度优先
随意起个昵称1 小时前
【递归】二进制字符串中的第K位
c++·算法
mjhcsp2 小时前
C++ 循环结构:控制程序重复执行的核心机制
开发语言·c++·算法
立志成为大牛的小牛2 小时前
数据结构——四十一、分块查找(索引顺序查找)(王道408)
数据结构·学习·程序人生·考研·算法
xier_ran2 小时前
深度学习:RMSprop 优化算法详解
人工智能·深度学习·算法
地平线开发者3 小时前
不同传感器前中后融合方案简介
算法·自动驾驶
地平线开发者3 小时前
征程 6X 常见 kernel panic 问题
算法·自动驾驶
com_4sapi4 小时前
2025 权威认证头部矩阵系统全景对比发布 双榜单交叉验证
大数据·c语言·人工智能·算法·矩阵·机器人
前端小L4 小时前
二分查找专题(九):“降维”的魔术!将二维矩阵“拉平”为一维
数据结构·算法