蓝桥杯历届真题--#R格式(C++,Java) 高精度运算

文章目录


题目解读

原题链接

题目描述

小蓝最近在研究一种浮点数的表示方法: R R R 格式。对于一个大于 0 0 0 的浮点数 d d d,可以用 R R R 格式的整数来表示。给定一个转换参数 n n n,将浮点数转换为 R R R 格式整数的做法是:

  1. 将浮点数乘以 2 n 2^n 2n。
  2. 四舍五入到最接近的整数。

输入格式

一行一个整数 n n n 和一个浮点数 d d d。

输出格式

一行一个整数表示 d d d 用 R R R 格式表示出的值。

样例 1 解释

3.14 × 2 2 = 12.56 3.14 \times 2^2 = 12.56 3.14×22=12.56,四舍五入后为 13 13 13。

数据规模与约定

用 t t t 表示将 d d d 视为字符串时的长度。

  • 对于 50 % 50\% 50% 的数据,保证 n ≤ 10 n \le 10 n≤10, t ≤ 15 t \le 15 t≤15。
  • 对于全部的测试数据,保证 1 ≤ n ≤ 1000 1 \le n \le 1000 1≤n≤1000, 1 ≤ t ≤ 1024 1 \le t \le 1024 1≤t≤1024,保证 d d d 是小数,即包含小数点。

思路

高精度计算即可

完整题解

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

void mul(vector<int>& a, int b) {
    int t = 0;
    for (int i = 0; i < a.size(); i++) {
        t += a[i] * b;
        a[i] = t % 10;
        t /= 10;
    }
    if (t)a.push_back(t);
    while (a.back() == 0 && a.size() > 1)a.pop_back();
}

void add(vector<int>& a, int k, int b) {
    int t = b;
    for (int i = k; i < a.size(); i++) {
        t += a[i];
        a[i] = t % 10;
        t /= 10;
    }
    if (t)a.push_back(t);
}

int main() {
    int n;
    //浮点数d的长度最大1024位,这里用字符串存下
    string d;
    cin >> n >> d;

    vector<int> D;
    reverse(d.begin(), d.end());
    //存储小数点的位置
    int dot = d.find('.');
    for (int i = 0; i < d.size(); i++) {
        if (d[i] != '.')D.push_back(d[i] - '0');
    }


    while (n--)mul(D, 2);
    //找小数点的后一位,看看是不是大于等于5,如果大于等于5那么小数点前一位+1
    //3.14 -> 41.3 反转之后找小数点后一位就是dot-1下标对应的数字
    if (D[dot - 1] >= 5)add(D, dot, 1);

    for (int i = D.size() - 1; i >= dot; i--)cout << D[i];
    return 0;
}
java 复制代码
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.util.*;

class Main{
    static Scanner sc =new Scanner(System.in);

    public static void main(String args[]) {
        int n=sc.nextInt();
        String d=sc.next();
        BigDecimal dd=new BigDecimal(d);

        //求2的n次方
        BigDecimal num1=new BigDecimal(2).pow(n);
        //2的n次方 乘以 浮点数d
        BigDecimal num2=num1.multiply(dd);
        //设置精度
        BigDecimal ans = num2.setScale(0,RoundingMode.HALF_UP);
        System.out.println(ans);
    }
}

参考

Acwing


🌻编写本篇文章目的是笔者想以输出的形式进行学习,顺便记录学习点滴🌻

🌹 如果本篇文章对你有帮助的话那就点个赞吧👍🌹

😇 本篇文章可能存在多处不足,如有修改意见,可以私信或者评论我哦 😇


相关推荐
毕设源码-钟学长9 分钟前
【开题答辩全过程】以 基于javaweb的音乐节管理系统为例,包含答辩的问题和答案
java·eclipse
zmzb010316 分钟前
C++课后习题训练记录Day91
开发语言·c++
启山智软16 分钟前
供应链商城核心功能模块清单
java·前端·开源
怡步晓心l17 分钟前
Mandelbrot集合的多线程并行计算加速
c++·算法·缓存
是萧萧吖24 分钟前
每日一练——有效的括号
java·开发语言·javascript
今儿敲了吗28 分钟前
07| 高精度除法
c++
程序员欣宸29 分钟前
LangChain4j实战之十六:RAG (检索增强生成),Naive RAG
java·人工智能·ai·langchain4j
qq_3363139344 分钟前
javaweb-Maven
java·maven
Sayuanni%344 分钟前
数据结构_Map和Set
java·数据结构
Demon_Hao1 小时前
Spring Boot开启虚拟线程ScopedValue上下文传递
java·spring boot·后端