高精度算法总结
高精度加法
题目链接:
https://www.acwing.com/activity/content/problem/content/825/
代码模版:
#include <iostream>
#include <vector>using namespace std;// C = A + B
vector<int> add(vector<int> &A, vector<int> &B)
{vector<int> C;int t = 0; // 进位for (int i = 0; i < A.size() || i < B.size(); i++){if (i < A.size()) t += A[i];if (i < B.size()) t += B[i];C.push_back(t % 10);t /= 10;}if (t) C.push_back(1);return C;
}int main()
{string a, b;vector<int> A, B;cin >> a >> b; // a = "123456"for (int i = a.size() - 1; i >= 0; i--) A.push_back(a[i] - '0'); // A = [6, 5, 4, 3, 2, 1]for (int i = b.size() - 1; i >= 0; i--) B.push_back(b[i] - '0');auto C = add(A, B);for (int i = C.size() - 1; i >= 0; i--) printf("%d", C[i]);return 0;
}
高精度减法
题目链接:
https://www.acwing.com/activity/content/problem/content/826/
代码模版:
#include <iostream>
#include <vector>using namespace std;// 判断是否有 A >= B
bool cmp(vector<int> &A, vector<int> &B)
{if (A.size() != B.size()) return A.size() > B.size();for (int i = A.size() - 1; i >= 0; i--)if (A[i] != B[i])return A[i] > B[i];return true;
}// C = A - B
vector<int> sub(vector<int> &A, vector<int> &B)
{vector<int> C;for (int i = 0, t = 0; i < A.size(); i++){t = A[i] - t;if (i < B.size()) t -= B[i];C.push_back((t + 10) % 10);if (t < 0) t = 1;else t = 0;}while (C.size() > 1 && C.back() == 0) C.pop_back(); // 去掉前导0return C;
}int main()
{string a, b;vector<int> A, B;cin >> a >> b; // a = "123456"for (int i = a.size() - 1; i >= 0; i--) A.push_back(a[i] - '0'); // A = [6, 5, 4, 3, 2, 1]for (int i = b.size() - 1; i >= 0; i--) B.push_back(b[i] - '0');if (cmp(A, B)){auto C = sub(A, B);for (int i = C.size() - 1; i >= 0; i--) printf("%d", C[i]);}else{auto C = sub(B, A);printf("-");for (int i = C.size() - 1; i >= 0; i--) printf("%d", C[i]);}return 0;
}
高精度乘法(高精度 × 低精度)
题目链接:
https://www.acwing.com/problem/content/795/
代码模版:
#include <iostream>
#include <vector>using namespace std;// C = A * b
vector<int> mul(vector<int> &A, int b)
{vector<int> C;int t = 0; // 进位for (int i = 0; i < A.size() || t; i++){if (i < A.size()) t += A[i] * b;C.push_back(t % 10);t /= 10;}while (C.size() > 1 && !C.back()) C.pop_back();return C;
}int main()
{string a;int b;vector<int> A;cin >> a >> b;for (int i = a.size() - 1; i >= 0; i--) A.push_back(a[i] - '0');auto C = mul(A, b);for (int i = C.size() - 1; i >= 0; i--) printf("%d", C[i]);return 0;
}
高精度乘法(高精度 × 高精度)
题目链接:
https://www.luogu.com.cn/problem/P1303
代码模版:
#include <iostream>
#include <vector>using namespace std;vector<int> mul(vector<int> &A, vector<int> &B)
{vector<int> C(A.size() + B.size());for (int i = 0; i < A.size(); i++)for (int j = 0; j < B.size(); j++)C[i + j] += A[i] * B[j];for (int i = 0, t = 0; i < C.size() || t; i++){t += C[i];if (i >= C.size()) C.push_back(t % 10);else C[i] = t % 10;t /= 10;}while (C.size() > 1 && !C.back()) C.pop_back();return C;
}int main()
{string a, b;vector<int> A, B;cin >> a >> b;for (int i = a.size() - 1; i >= 0; i--) A.push_back(a[i] - '0');for (int i = b.size() - 1; i >= 0; i--) B.push_back(b[i] - '0');auto C = mul(A, B);for (int i = C.size() - 1; i >= 0; i--) cout << C[i];return 0;
}
高精度除法
题目链接:
https://www.acwing.com/problem/content/796/
代码模版:
#include <iostream>
#include <vector>
#include <algorithm>using namespace std;// A / b,商是C,余数是r
vector<int> div(vector<int> &A, int b, int &r) // r是引用
{vector<int> C; // 商r = 0;for (int i = A.size() - 1; i >= 0; i--){r = r * 10 + A[i];C.push_back(r / b);r %= b;}reverse(C.begin(), C.end());while (C.size() > 1 && !C.back()) C.pop_back();return C;
}int main()
{string a;int b;vector<int> A;cin >> a >> b;for (int i = a.size() - 1; i >= 0; i--) A.push_back(a[i] - '0');int r;auto C = div(A, b, r);for (int i = C.size() - 1; i >= 0; i--) printf("%d", C[i]);cout << endl << r << endl;return 0;
}
相关文章:
高精度算法总结
高精度加法 题目链接: https://www.acwing.com/activity/content/problem/content/825/ 代码模版: #include <iostream> #include <vector>using namespace std;// C A B vector<int> add(vector<int> &A, vector<…...
EMQX-5.3.1单机集群部署并基于Nginx实现负载均衡
本例单机集群部署使用三个节点,分别为node1、node2、node3 一、安装与配置 1 创建数据目录 mkdir -p node1/data node1/logs mkdir -p node2/data node2/logs mkdir -p mode3/data node3/logs 2 数据目录授权 chown 1000 node1/ node2/ node3/ chown 1000 n…...
电商又有大动静,又一短视频进军电商领域!
我是电商珠珠 电商近几年来发展迅速,截止到23年的10月26日,电商零售平台市场份额是淘宝市场占比的53%,京东为20%,拼多多手握15%的市场占比,三者合计份额已经达到了88%。 剩下的抖音、快手、苏宁也在奋力抢占更多。 …...
C语言线性表的链式存储(框架)
线性表的链式存储 线性表的顺序存储:用一块连续的内存空间 线性表的链式存储:不连续的内存空间 链表是由一系列的节点组成,每个节点包含两个域,一个是数据域,一个是指针域 链表的插入和删除原理 单项链表框架的搭建 …...
webpack配置完热更新之后还是会刷新整个页面
可以在webpack文档中找到有关热更新的详细信息,意思就是,开启热更新之后,整个页面你改了哪里,就只更新哪里,其他没变的,或者保存在缓存里面的内容,都不会改变,感谢很神奇!…...
2023年第六届传智杯程序设计挑战赛(个人赛)B组 赛后复盘
传智杯赛后复盘 大家好 我是寸铁👊 2023年第六届传智杯程序设计挑战赛(个人赛)B组 赛后复盘 喜欢的小伙伴可以点点关注 💝 1. 字符串拼接 细节:一定要清楚nextLine()和next()的区别 nextLine()是遇到回车会停下来 nex…...
C语言——深入理解指针(2)
目录 1. 数组名 2. 指针访问数组 3. 一维数组的传参(本质) 4. 冒泡排序 5. 二级指针 6. 指针数组(指针的数组) 7. 指针数组模拟二维数组 1. 数组名 在之前的代码中我们使用指针访问过数组的内容。 int arr[10] {1,2,3,4…...
【已解决】HBase 2.2.6 集群部署后,从节点未启动 HRegionServer
问题发现 今天搭建了 HBase 2.2.6 集群环境,启动之后发现,从节点的 HRegionServer 未启动。多次对比参数设置仍然未发现异常。而启动之前的 HBase 2.4.11 则完成正常,我就有点怀疑是不是 HBase 2.2.6 集群搭建有什么特殊的地方? …...
JVM——垃圾回收(方法区中的垃圾回收和(堆回收)自动垃圾回收)
目录 1.自动垃圾回收介绍1.C/C的内存管理2.Java的内存管理3.垃圾回收的对比 2.方法区的回收方法区的回收 – 手动触发回收 3.堆回收1.引用计数法2.可达性分析算法 1.自动垃圾回收介绍 1.C/C的内存管理 ⚫ 在C/C这类没有自动垃圾回收机制的语言中,一个对象如果不再…...
Flink 常用物理分区算子(Physical Partitioning)
Flink 物理分区算子(Physical Partitioning) 在Flink中,常见的物理分区策略有:随机分配(Random)、轮询分配(Round-Robin)、重缩放(Rescale)和广播(Broadcast)。 接下来,我们通过源码和Demo分别了解每种物理分区算子的作用和区别。 (1) 随机…...
Leetcode.560 和为 K 的子数组
题目链接 Leetcode.560 和为 K 的子数组 mid 题目描述 给你一个整数数组 n u m s nums nums 和一个整数 k k k ,请你统计并返回 该数组中和为 k k k 的子数组的个数 。 子数组是数组中元素的连续非空序列。 示例 1: 输入:nums [1,1,1]…...
linklab phase1 更简单的方法
直接反汇编phase1.o,看eax中是0x21,0x21在数据域中,直接把从第21个字节的内容改为0000000000即可。...
8.前端--CSS-文本属性【2023.11.26】
CSS Text(文本)属性可定义文本的外观,比如文本的颜色、对齐文本、修饰文本、文本缩进、行间距等 1.文本颜色 color 属性用于定义文本的颜色。 语法: div { color: red; }属性: 2.文本对齐 text-align 属性用于设置元…...
容器技术——Cgroup
目录 容器技术容器技术概述要区分好共享与隔离的概念容器技术的三大核心容器对比虚拟机 namespaceUnionFs容器操作系统的来源操作系统的来源完整操作系统的镜像docker image是什么?如何构成的 如何为容器安装操作系统UnionFS(联合文件系统)的…...
uniapp+vue3路由跳转传参
在uni-app中使用Vue 3进行路由跳转传参,可以通过以下步骤实现: 1.在router文件夹中创建一个名为index.js的文件,用于配置路由。在这个文件中,我们将导入createRouter和createWebHistory函数,并定义路由规则。同时&…...
流量主如何在广告收益和用户体验中找到平衡
流量主在广告收益和用户体验之间找到平衡是一个关键的挑战,因为过多或不恰当的广告可能会影响到用户的满意度和留存率。以下是一些方法,可以帮助流量主在这两者之间找到平衡: admaoyan猫眼聚合 优质内容为先: 提供高质量、有价值的…...
RPC和HTTP的区别
目录 1、RPC是什么 1.1 概念 1.2 RPC的组成部分 1.3 常见的 RPC 技术和框架 1.4 RPC的工作流程 2、HTTP是什么 2.1 概念 2.2 HTTP的消息格式 2.3 HTTP响应状态码有哪些 3、⭐RPC和HTTP的区别 小结 1、RPC是什么 1.1 概念 RPC(Remote Procedure Call&am…...
Dubbo3使用Zookeeper作为注册中心的方案讨论!详解DubboAdmin与PrettyZoo来监控服务的优劣!
文章目录 一:Dubbo注册中心的基本使用 二:Zookeeper注册中心的使用 1:依赖引入 2:实际开发 三:Zookeeper作为注册中心的使用展示 1:启动注册Zookeeper服务 2:引入注册中心 (一)…...
前端uni微信小程序和后端nodejs使用websoket
需求 前端向后台服务器发请求获取验证码,然后端游输入验证码,向我的后端发请求获取验证信息。后台给游戏端返回信息的时候同时给微信小程序端返回验证结果。意思是不要微信小程序端主动触发,验证是否绑定的请求。 思路 后端生成验证码时存…...
java小游戏之【王者荣耀】
首先创建一个新的Java项目命名为“王者荣耀”,并在src下创建两个包分别命名为“com.sxt"、”com.stx.beast",在相应的包中创建所需的类。 代码 package com.sxt;import javax.swing.*; import java.awt.*;public class Background extends GameObject {p…...
YOLOv13镜像实战效果:复杂场景下目标识别依然精准
YOLOv13镜像实战效果:复杂场景下目标识别依然精准 1. 引言:当目标检测遇上复杂场景 想象一下这样的场景:一个繁忙的十字路口,行人穿梭、车辆交错、自行车穿行,还有各种交通标志和广告牌。在这样的复杂环境中…...
大一初学C语言
我是一名大一学生,专业是自动化,我了解 C 语言对我们这个专业很重要,所以我想学习 C语言 为以后更深入的学习打下基础,每天的话 我可以拿出两个小时左右时间来学习,争取在大二前把 C 语言基础弄懂 ,然后学习…...
办公自动化必备!MinerU智能文档理解镜像实战:提升文档处理效率10倍
办公自动化必备!MinerU智能文档理解镜像实战:提升文档处理效率10倍 1. 引言:文档处理的效率革命 每天早晨,财务部门的李经理都要面对堆积如山的发票和报表。传统的人工录入方式不仅耗时费力,还容易出错。类似的情况也…...
零基础玩转Z-Image-Turbo-辉夜巫女:8步生成高质量图片,小白也能当AI画师
零基础玩转Z-Image-Turbo-辉夜巫女:8步生成高质量图片,小白也能当AI画师 1. 引言:人人都能成为AI画师 你是否曾经羡慕那些能随手画出精美插画的大触?现在,借助Z-Image-Turbo-辉夜巫女这个AI工具,零基础的…...
WarcraftHelper:让经典魔兽争霸III在现代系统上重获新生
WarcraftHelper:让经典魔兽争霸III在现代系统上重获新生 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 你是否还记得那些在网吧通宵鏖战魔…...
LangGraph 实战指南:拒绝 AI 应用面条代码,像搭地铁一样构建企业级 Agent
LangGraph 实战指南:拒绝 AI 应用面条代码,像搭地铁一样构建企业级 Agent 文章目录LangGraph 实战指南:拒绝 AI 应用面条代码,像搭地铁一样构建企业级 Agent前言:那个让程序员崩溃的周五晚上一、LangGraph 是什么&…...
YOLO12实时目标检测模型应用:工业质检场景下的缺陷检测
YOLO12实时目标检测模型应用:工业质检场景下的缺陷检测 1. 工业质检场景的技术挑战 工业质检是制造业中至关重要的环节,传统人工检测方式面临三大核心挑战: 效率瓶颈:人工检测速度通常在0.5-2秒/件,难以满足现代生产…...
Replit AI 零基础编程使用教程:从 0 到 1 玩转 AI 辅助开发
前言 还在为搭建开发环境头疼?还在因为编程基础薄弱写不出代码?Replit AI 作为一款浏览器原生、零配置、AI 驱动的全栈开发平台,完美解决了这些问题。它能让你从一个简单的想法出发,通过自然语言对话,快速生成、调试、…...
CYBER-VISION零号协议实战:从零到一搭建智能助盲眼镜目标分割系统
CYBER-VISION零号协议实战:从零到一搭建智能助盲眼镜目标分割系统 1. 项目背景与核心价值 想象一下,当你走在繁忙的街道上,眼前的一切都是模糊不清的。这就是视障人群每天面临的挑战。传统的导盲杖只能提供有限的触觉反馈,而CYB…...
【限时公开】SITS2026实验室未发布数据:92.7%的商用大模型API在无防护下3.8秒内被FGSM变体攻破?
第一章:SITS2026专家:大模型对抗攻击防护 2026奇点智能技术大会(https://ml-summit.org) 在大模型规模化部署的背景下,对抗样本攻击正从学术威胁演变为真实业务风险——微小扰动即可导致LLM输出恶意指令、泄露训练数据或绕过安全护栏。SITS…...
