(四舍五入) 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; 
    
}
相关推荐
白狐_79823 分钟前
【项目实战】我用一个 HTML 文件写了一个“CET-6 单词斩”
前端·算法·html
Jasmine_llq23 分钟前
《P3811 【模板】模意义下的乘法逆元》
数据结构·算法·线性求逆元算法·递推求模逆元
Jacob程序员27 分钟前
欧几里得距离算法-相似度
开发语言·python·算法
ffcf1 小时前
消息中间件6:Redis副本数变为0和删除PVC的区别
算法·贪心算法
CoderYanger1 小时前
动态规划算法-斐波那契数列模型:2.三步问题
开发语言·算法·leetcode·面试·职场和发展·动态规划·1024程序员节
sin_hielo1 小时前
leetcode 2211
数据结构·算法·leetcode
CoderYanger1 小时前
动态规划算法-简单多状态dp问题:16.买卖股票的最佳时机含手续费
开发语言·算法·leetcode·动态规划·1024程序员节
严文文-Chris1 小时前
【半监督学习常见算法】
学习·算法·机器学习
FPGA_无线通信1 小时前
OFDM 同步设计(3)
算法·fpga开发
SHOJYS2 小时前
离散化+二位前缀和的计数题 [USACO20DEC] Rectangular Pasture S
算法