【2024.9.29练习】R 格式

news/2024/9/30 12:38:12 标签: 算法

题目描述


题目分析

带小数点的高精度乘法。小数点在计算时忽略,只需在最终打印字符串的时候在合适位置四舍五入即可。对于d\times 2^n,可理解为对d乘2总共n次。因此使用“单精度×高精度”类型的算法足矣。


我的代码

一开始代码有错误,我只想到了对小数点前最后一位四舍五入,却没想到末位进一之后可能会满10,然后要再向前一位借1。后面又写了一个进位函数解决了问题。

并且一开始的最大数组长度写小了LEN=1024,考虑到还有2^{1000}的系数,应该再增加300位。测试用例果真说明如此。看来以后数组长度能开大还是尽量大一些。

#include <iostream>
#include <algorithm>
#include <string>
using namespace std;
const int LEN = 2030; //数组最大长度
//预处理
void clear(int a[]) {
	for (int i = 0; i < LEN; ++i) a[i] = 0;
}
//是否有浮点
int p = 0; //默认的小数点在第几位之前
bool check_point(string s) {
    int len = s.length();
    for (int i = 0; i < len; i++) {
        if (s[i] == '.') {
            p = len - i - 1;
            return true;
        }
    }
    return false;
}
//读取字符串并转换为高精度数组
void read(int a[]) {
    string s;
    cin >> s;
	clear(a);
	int len = s.length();
    if (check_point(s)) {
        int j = 0;
        for (int i = 0; i < len; i++) {
            if (s[i] == '.') {
                j--;
            }
            else {
                a[len - j - 2] = s[i] - '0';
            }
            j++;
        }
    }
    else {
        for (int i = 0; i < len; i++) a[len - i - 1] = s[i] - '0';
    }
}
//高精度×单精度
void mul_short(int a[], int b, int c[]) {
    clear(c);

    for (int i = 0; i < LEN - 1; ++i) {
        c[i] += a[i] * b;
        if (c[i] >= 10) {
            c[i + 1] += c[i] / 10;
            c[i] %= 10;
        }
    }
}
//数组复制
void copyy(int a[],int b[]) { //a to b
    clear(b);
    for (int i = 0; i < LEN; i++) {
        b[i] = a[i];
    }
}
void print(int a[]) {
    int i;
    for (i = LEN - 1; i >= p+1; i--)
        if (a[i] != 0) break;
    for (; i >= p; --i) cout << a[i];
}
void print2(int a[]) {
    int i;
    for (i = LEN - 1; i >= 1; --i)
        if (a[i] != 0) break;
    for (; i >= 0; --i) putchar(a[i] + '0');
    putchar('\n');
}
void addone(int a[],int p) {
    a[p]++;
    if (a[p] >= 10) {
        a[p] %= 10;
        addone(a,p+1);
    }
}
int d[LEN];
int ans[LEN];
int main() {
    int n;
    cin >> n;
    read(d);
    //乘2共n次
    for (int i = 0; i < n; i++)
    {
        mul_short(d, 2, ans);
        copyy(ans, d);
    }
    //print2(ans);
    if (ans[p - 1] > 4) {
        addone(ans,p);
    }
    print(ans);
	return 0;
}

这道题不仅函数不完全是我自己写的(因为记不住),而且编写和纠错过程也十分漫长,常常被自己绕晕。高精度运算函数默写难度还是很大的,目前自己各方面的水平都还完全不行,要熟练掌握算法还需多加训练和思考!!


http://www.niftyadmin.cn/n/5685116.html

相关文章

Mac pnpm安装

安装pnpm的时候一定要把npm更新到最新版 不然pnpm下载不成功。 &#xff08;更新npm&#xff09;&#xff1a;sudo npm install -g npm (安装pnpm:) sudo npm install -g pnpm 检验安装是否成功&#xff1a;pnpm --version 项目内安装依赖&#xff1a;pnpm install / 运行项目&…

用C++游戏开发

引言 C被广泛使用于游戏开发中&#xff0c;这是因为它提供了高性能、灵活的内存管理&#xff0c;以及与硬件的低级别交互能力。在这篇文章中&#xff0c;我们将介绍C游戏开发的基础知识&#xff0c;包括游戏引擎的选择、基本的编程概念以及一些实践建议。 C在游戏开发中的优势…

二值图像的面积求取的两种方法及MATLAB实现

一、引言 面积在数字图像处理中经常用到&#xff0c;在MATLAB中&#xff0c;计算二值图像的面积通常可以通过两种主要方法实现&#xff1a;遍历法和直接利用bwarea函数。下面将分别介绍这两种方法的原理和相应的MATLAB代码示例。 二、遍历法计算二值图像面积的原理和MATLAB代码…

PostgreSQL是否有等待事件

PostgreSQL是否有等待事件 PostgreSQL 提供了等待事件&#xff08;Wait Events&#xff09;的机制&#xff0c;用于监控数据库运行过程中因资源争用而导致的等待情况。这些等待事件可以帮助数据库管理员识别导致性能问题的瓶颈&#xff0c;例如锁冲突、I/O 等待等。 什么是等…

【快速删除 node_modules 】rimraf

目录 1. 什么是node_modules 2. 卸载一个npm包 3. 删除 node_modules 为什么这么慢 4. rimraf 5. 为什么rimraf 这么快 作为前端开发&#xff0c;无论我们关注不关注&#xff0c;每天都能接触到node_modules。通常产生于一个npm install命令&#xff0c;之后就不会多加关注…

深度学习--------------------------------门控循环单元GRU

目录 门候选隐状态隐状态门控循环单元GRU从零开始实现代码初始化模型参数定义隐藏状态的初始化函数定义门控循环单元模型训练该部分总代码简洁代码实现 做RNN的时候处理不了太长的序列&#xff0c;这是因为把整个序列信息全部放在隐藏状态里面&#xff0c;当时间很长的话&#…

C++的6种构造函数

在 C 中&#xff0c;构造函数是一种特殊的成员函数&#xff0c;用于初始化类对象。在对象创建时自动调用&#xff0c;构造函数的主要作用是分配资源、初始化数据成员等。根据不同的功能和使用场景&#xff0c;C 提供了多种类型的构造函数&#xff1a; 1. 默认构造函数 (Defaul…

MySQL 索引最左匹配原则详解

MySQL 索引最左匹配原则详解 在使用 MySQL 数据库进行查询优化时&#xff0c;索引是一项至关重要的工具。理解索引的最左匹配原则及其底层实现原因&#xff0c;对于编写高效的 SQL 查询至关重要。本文将深入讲解 MySQL 索引最左匹配原则&#xff0c;为什么不满足最左匹配原则会…