蓝桥杯 R格式

问题描述

小蓝最近在研究一种浮点数的表示方法:R 格式

对于一个大于 0 的浮点数 d,可以用 R 格式的整数来表示。

给定一个转换参数 n,将浮点数转换为 R 格式整数的做法是:

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

输入格式

一行输入一个整数 n 和一个浮点数 d,分别表示转换参数和待转换的浮点数。


输出格式

输出一行表示答案:d 用 R 格式表示出来的值。


样例输入

in 复制代码
2 3.14

样例输出

out 复制代码
13

样例说明

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


评测用例规模与约定

  • 对于 50% 的评测用例:
    1 ≤ n ≤ 10,d 的字符串长度 ≤ 15;
  • 对于 100% 的评测用例:
    1 ≤ n ≤ 1000,d 的字符串长度 ≤ 1024,保证 d 是小数(即包含小数点)。

c++代码

cpp 复制代码
#include<bits/stdc++.h>
#include<stdio.h>

using namespace std;

int n;
string d;

string highmutiple(string a, string b) {
    if (a == "0" || b == "0") return "0";
    int m = a.size(), n = b.size();
    vector<int> aa(m), bb(n), cc(m + n, 0);
    for (int i = 0; i < m; i++) {
        aa[i] = a[m - i - 1] - '0';
    }
    for (int i = 0; i < n; i++) {
        bb[i] = b[n - i - 1] - '0';
    }
    for (int i = 0; i < m; i++) {
        for (int j = 0; j < n; j++) {
            cc[i + j] += aa[i] * bb[j];
            cc[i + j + 1] += cc[i + j] / 10;
            cc[i + j] %= 10;
        }
    }
    string c;
    int k = m + n - 1;
    while(cc[k] == 0) k--;
    while(k >= 0) {
        c += to_string(cc[k]);
        k--;
    }
    return c;
}

string addone(string a) {
    int m = a.size();
    vector<int> aa(m + 1);
    for (int i = 0; i < m; i++) {
        aa[i] = a[m - i - 1] - '0';
    }
    aa[0]++;
    for (int i = 0; i < m; i++) {
        aa[i + 1] += aa[i] / 10;
        aa[i] %= 10;
    }
    string b;
    int k = m;
    if (aa[m] == 0) k--;
    while(k >= 0) {
        b += to_string(aa[k]);
        k--;
    }
    return b;
}

int main() {
    cin >> n >> d;
    string a = "1";
    while(n--) {
        a = highmutiple(a, "2");
    }
    int k = d.find(".");
    d.erase(k, 1);
    string ans = highmutiple(a, d);
    string zhen = ans.substr(0, ans.size() - (d.size() - k));
    if (ans[ans.size() - (d.size() - k)] >= '5') zhen = addone(zhen);
    cout << zhen;
    return 0;
}//by wqs

解题思路

高精度问题

计算的时候把小数点去掉,记录小数点后面有多少位。d有多少位小数,答案就有多少位小数

四舍五入只要判断小数点后的一位是不是比5大就行了。

相关推荐
程序员小远1 小时前
接口自动化测试知识总结
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
2301_793102491 小时前
c++——STL容器之vector
c++·stl
CCPC不拿奖不改名1 小时前
Python基础:python语言中的文件操作+面试题目
开发语言·数据结构·人工智能·python·学习·面试·职场和发展
程序炼丹师1 小时前
C++ 中的 std::tuple (元组)的使用
开发语言·c++
有一个好名字1 小时前
力扣-最大连续1的个数III
c++·算法·leetcode
橘颂TA1 小时前
【剑斩OFFER】算法的暴力美学——力扣 43 题:字符串相乘
数据结构·算法·leetcode·职场和发展·哈希算法·结构与算法
海边的Kurisu1 小时前
代码随想录算法第六十四天| To Be Continued
算法
less is more_09301 小时前
文献学习——极端高温灾害下电缆型配电网韧性提升策略研究
笔记·学习·算法
小芒果_011 小时前
P8662 [蓝桥杯 2018 省 AB] 全球变暖
c++·算法·蓝桥杯·信息学奥赛
漫随流水1 小时前
leetcode算法(199.二叉树的右视图)
数据结构·算法·leetcode·二叉树