当前位置: 首页 > article >正文

基础算法-高精度:高精度减法

P2142 高精度减法题目链接P2142 高精度减法 - 洛谷高精度的题目解法和之前高精度加法的解法基本相同所以就不再过多讲解原理了。解法模拟列竖式计算的过程。①先用字符串读入然后拆分每一位逆序放在数组中。但是我们需要提前判断a与b的大小要让大的减小的所以需要先进行判断。我们在比较数字大小时最简便的方法就是先比较两者有多少位如果相同再从高到低依次比较。由于我们要把a和b先读取为字符串所以我们可以直接先比较a字符串与b字符串的长度用size()函数如果相同直接用return ab;因为在string中重定义了我们可以直接使用它来比较#includeiostream #includestring using namespace std; const int N 1e6 10; int a[N], b[N], c[N]; int la, lb, lc; //比较两个数字的大小 bool cmp(const string x, const string y) { //比较长度 if (x.size() ! y.size())return x.size() y.size(); //按照字典序的方式比较 return x y; } int main() { string x, y; cin x y; if (cmp(x, y)) { //如果xy则需要交换x,y swap(x, y); //记得输出-因为已经确定xy所以运算结果中必定有- cout -; } //拆分每一位逆序放到数组中 la x.size(); lb y.size(); lc max(la, lb); for (int i 0; i la; i) { a[la - i - 1] x[i] - 0;//x[i]为字符! } for (int i 0; i lb; i) { b[lb - i - 1] y[i] - 0; } //模拟减法过程 sub(c, a, b);//ca-b; //输出结果 for (int i lc - 1; i 0; i--) { cout c[i]; } return 0; }接下来就完善减法过程了。②利用数组模拟列竖式减法的过程1先是对应位相减如果结果小于0则需要借位记得是a[i]b[i]因为如果该位置被前一位借位了这个位置为-12处理借位该位置后面一个位置-1然后这个位置10c[i]10完善逻辑后的结果为#includeiostream #includestring using namespace std; const int N 1e6 10; int a[N], b[N], c[N]; int la, lb, lc; //比较两个数字的大小 bool cmp(const string x, const string y) { //比较长度 if (x.size() ! y.size())return x.size() y.size(); //按照字典序的方式比较 return x y; } //高精度减法的模板- ca-b void sub(int c[], int a[], int b[]) { for (int i 0; i lc; i) { c[i] a[i] - b[i]; if (c[i] 0) { --c[i 1];//借位 c[i] 10; } } } int main() { string x, y; cin x y; if (cmp(x, y)) { //如果xy则需要交换x,y swap(x, y); //记得输出-因为已经确定xy所以运算结果中必定有- cout -; } //拆分每一位逆序放到数组中 la x.size(); lb y.size(); lc max(la, lb); for (int i 0; i la; i) { a[la - i - 1] x[i] - 0;//x[i]为字符! } for (int i 0; i lb; i) { b[lb - i - 1] y[i] - 0; } //模拟减法过程 sub(c, a, b);//ca-b; //输出结果 for (int i lc - 1; i 0; i--) { cout c[i]; } return 0; }如果此时复制代码到题目上会有为什么我们可以发现如果最高位相减如9-9最终结果为0而我们输出的时候这个0是需要省略的也就是说如果999-997最终结果应该为2而这样输出结果为002其次如果ab也就是说999-999最终得到的结果是0而如果把所有0省略那么最终没有输出所以我们需要再加个条件lc1并使用while循环来去掉前置0我们可以使用--lc的方式来去掉多余的前置0#includeiostream #includestring using namespace std; const int N 1e6 10; int a[N], b[N], c[N]; int la, lb, lc; //比较两个数字的大小 bool cmp(const string x, const string y) { //比较长度 if (x.size() ! y.size())return x.size() y.size(); //按照字典序的方式比较 return x y; } //高精度减法的模板- ca-b void sub(int c[], int a[], int b[]) { for (int i 0; i lc; i) { c[i] a[i] - b[i];//对应位相减然后借位 if (c[i] 0) { --c[i 1];//借位 c[i] 10; } } //处理前导零 while (lc 1 c[lc - 1] 0) { --lc; } } int main() { string x, y; cin x y; if (cmp(x, y)) { //如果xy则需要交换x,y swap(x, y); //记得输出-因为已经确定xy所以运算结果中必定有- cout -; } //拆分每一位逆序放到数组中 la x.size(); lb y.size(); lc max(la, lb); for (int i 0; i la; i) { a[la - i - 1] x[i] - 0;//x[i]为字符! } for (int i 0; i lb; i) { b[lb - i - 1] y[i] - 0; } //模拟减法过程 sub(c, a, b);//ca-b; //输出结果 for (int i lc - 1; i 0; i--) { cout c[i]; } return 0; }这样就可以运行成功了每次写这种题目的时候我们都要想到边界情况不要盲目写即可。

相关文章:

基础算法-高精度:高精度减法

P2142 高精度减法 题目链接:P2142 高精度减法 - 洛谷 高精度的题目解法和之前高精度加法的解法基本相同,所以就不再过多讲解原理了。 解法:模拟列竖式计算的过程。 ①先用字符串读入,然后拆分每一位,逆序放在数组…...

Leetcode普通数组-day5、6

Leetcode普通数组-day5/6记录自己刷力扣备战秋招的刷题笔记❤️ ​ ——wosz普通数组 普通数组没什么需要说的,其实最简单的办法就是遍历,因为普通数组它是连续的,因此不会涉及到很复杂的算法。 因为是遍历嘛,我们就可…...

LangChain教程-、Langchain基础来

简介 AI Agent 不仅仅是一个能聊天的机器人(如普通的 ChatGPT),而是一个能够感知环境、进行推理、自主决策并调用工具来完成特定任务的智能系统,更够完成更为复杂的AI场景需求。 AI Agent 功能 根据查阅的资料,agent的…...

Pokerobo_PSx:轻量级PS2手柄嵌入式驱动库

1. Pokerobo_PSx 库概述Pokerobo_PSx 是一个专为嵌入式系统设计的轻量级 PS2 DualShock 手柄通信协议栈,面向 STM32、ESP32、nRF52 等主流 MCU 平台,提供完整、稳定、可裁剪的 PlayStation 2 游戏手柄(含 DualShock 1/2 及兼容设备&#xff0…...

用 Microsoft Agent Framework 构建 SubAgent(Multi-Agent)伎

本文能帮你解决什么? 1. 搞懂FastAPI异步(async/await)到底在什么场景下能真正提升性能。 2. 掌握在FastAPI中正确使用多线程处理CPU密集型任务的方法。 3. 避开常见的坑(比如阻塞操作、数据库连接池耗尽、GIL限制)。 …...

PlayRtttl嵌入式音频引擎:轻量级RTTTL/RTX解析与实时播放

1. PlayRtttl 库深度技术解析:嵌入式平台上的 RTTTL/RTX 音频引擎实现1.1 库定位与工程价值PlayRtttl 是一个面向资源受限嵌入式平台的轻量级 RTTTL(Ring Tone Text Transfer Language)与 RTX(扩展版)音频解析与播放库…...

OpenClaw错误处理机制:Phi-3-vision识别失败自动重试方案

OpenClaw错误处理机制:Phi-3-vision识别失败自动重试方案 1. 为什么需要错误处理机制 上周我在用OpenClaw对接Phi-3-vision模型时,遇到了一个典型问题:当模型识别图片中的文字内容时,偶尔会出现识别失败或结果不准确的情况。这直…...

如何用 MutationObserver 监控第三方插件对 DOM 的篡改

使用MutationObserver监控第三方插件DOM篡改,需精准配置观察选项(childList、subtree、attributes、characterData),聚焦目标容器与可疑变更,安全修复防死循环,并兼顾兼容性与iframe等特殊场景。用 Mutatio…...

红外遥控技术原理与工程实践详解

1. 红外遥控的基本原理红外遥控技术是现代电子设备中最常见的无线控制方式之一。它的核心原理是利用红外光作为信息载体,在发射端和接收端之间建立通信链路。这种看似简单的技术背后,其实蕴含着精妙的物理原理和电子设计。红外光的波长范围通常在700纳米…...

I²C从机块传输驱动:高效实现多字节同步收发

1. 项目概述lib_i2c_slave_block是一个专为嵌入式系统设计的 IC 从机端块传输驱动库,其核心目标是解决标准 HAL 或 LL 库在 IC 从机模式下对连续多字节数据收发支持不足的问题。在实际工业与消费类电子应用中(如传感器集线器、EEPROM 扩展模块、多通道 A…...

龙芯k - 走马观碑组MPU驱动移植孟

先回顾:三次握手(建立连接)核心流程(实际版) 为了让挥手流程衔接更顺畅,咱们先快速回顾三次握手的实际核心,避免上下文脱节: 第一步(客户端→服务器)&#xf…...

F-Theta扫描透镜的性能评估

摘要F-Theta透镜通常用于基于扫描式的激光材料加工系统。使用这种透镜,聚焦光斑沿目标平面的位移与透镜焦距和扫描角度的乘积成正比。然而,不存在完美的F-Theta系统,因此在任何给定的系统中,偏离理想行为的偏差都是可以预期的。借…...

某大型园区服务集团薪酬体系与总额管控优化项目成功案例纪实

——对标市场、分类施策,构建支撑国际化转型的薪酬激励新机制【客户行业】园区服务;物业管理;文旅服务;国有企业【问题类型】薪酬体系改革;薪酬总额管控【客户背景】某大型园区服务集团隶属于某大型央企,位…...

Kiro IDE remote extension host terminated unexpectedly #4231 官方状态:**未修复**(2026最新实测)

【重要】Kiro AI 远程连接崩溃问题 #4231 官方状态:未修复(2026最新实测) 文章目录【重要】Kiro AI 远程连接崩溃问题 #4231 官方状态:**未修复**(2026最新实测)问题描述复现条件官方 Issue 真实状态影响范…...

TechWiz OLED应用:OLED中偏振光源的分析

1. 建模任务 1.1. 模拟条件  光源: EML Emitter (Unit source)  偶极子方向: Polarization  ExEy1/Phase-90˚, 90˚ (circular polarization)  波长: 380~780 nm (10 nm step)  视角: Theta: 0˚~90˚(10˚ step)/ Phi: 0˚~360˚(10˚ step) 1.2 堆栈结构 2.…...

OCAD应用:多重转换式断续变焦系统设计

多组转换型变焦系统可以实现多档断续变焦。设计时同时设计多重可打入活动组,在打入时随意转换。多组转换型的活动组可以放置在会聚光路中也可以在平行光路中。选择在平行光路中,可利用活动组的无焦性来回倒置获得放大缩小两种不同变焦效果。 图1.多组转…...

基于MATLAB/Simulink的纯电动汽车模型( (包括驾驶员模型,电机模型,电池模型,传动模型,纵向动力学模型)

基于MATLAB/Simulink的纯电动汽车模型( (包括驾驶员模型,电机模型,电池模型,传动模型,纵向动力学模型),比较简单,适合零基础或初学者,标准的 Simulink 纯电动…...

Boodskap数字孪生Arduino客户端库深度解析

1. Boodskap IoT Digital Twin Arduino客户端库深度解析Boodskap IoT Digital Twin Arduino Client Library 是一款面向嵌入式边缘设备的轻量级物联网通信中间件,专为将Arduino生态(尤其是ESP32系列)传感器节点快速接入Boodskap Twinned数字孪…...

嵌入式文件传输协议选型与优化实践

1. 嵌入式文件传输协议概述在嵌入式系统开发中,文件传输是设备间数据交换的基础功能。不同于PC环境,嵌入式设备往往受限于资源(内存、CPU、存储)和网络条件(带宽、稳定性),需要专门优化的传输方…...

嵌入式系统开发:硬件思维与架构实践

1. 嵌入式领域的技术特性解析嵌入式系统开发与传统软件工程存在本质差异。在资源受限的硬件环境中,开发者往往需要直接操作寄存器、管理内存分配、处理中断服务例程。这种"贴近金属"的开发方式,决定了嵌入式工程师必须具备硬件思维。以STM32系…...

AI编程实战:从零到一搭建全栈项目胺

1. 核心概念 在 Antigravity 中,技能系统分为两层: Skills (全局库):实际的代码、脚本和指南,存储在系统级目录(如 ~/.gemini/antigravity/skills)。它们是“能力”的本体。 Workflows (项目级)&#xff1a…...

OpenClaw备份恢复方案:Qwen3-32B任务历史与技能配置迁移

OpenClaw备份恢复方案:Qwen3-32B任务历史与技能配置迁移 1. 为什么需要备份OpenClaw工作区 上周我的主力开发机突然硬盘故障,导致整个~/.openclaw目录丢失。当时正在运行的3个自动化流程(日报生成、竞品监控、数据清洗)全部中断…...

金融PHP支付配置终极Checklist(2024Q3央行金融科技新规适配版):58项必检条目,漏1项即触发监管通报

第一章:金融PHP支付配置的监管合规基线定义在金融级PHP支付系统中,监管合规不是可选优化项,而是架构设计的前置约束条件。监管基线定义涵盖数据安全、交易可追溯性、资金隔离、审计留痕及持牌资质映射五大核心维度,其技术实现必须…...

从零构建可审计、可回滚、可监控的向量检索服务:EF Core 10架构设计图+DDD分层实践(含GitHub可运行Demo)

第一章:EF Core 10向量检索服务的核心定位与演进背景EF Core 10首次将原生向量检索能力深度集成至ORM层,标志着.NET数据访问技术从传统关系型查询迈向语义化、多模态检索的新阶段。这一演进并非孤立功能叠加,而是响应大语言模型应用爆发、RAG…...

Linux相关概念和易错知识点(52)(基于System V的信号量和消息队列)

目录1、System V信号量(1)信号量的本质与核心原理(2)PV原语(均为原子操作)a. P原语(申请资源)b. V原语(归还资源)(3)System V信号量接…...

MCP3221 12位I²C ADC驱动设计与精度优化实战

1. MCP3221 12位IC模数转换器底层驱动技术解析MCP3221是Microchip公司推出的超低功耗、单通道、12位分辨率的串行模数转换器(ADC),采用标准IC总线接口,工作电压范围宽达2.7V至5.0V,静态电流典型值仅仅为1.5μA&#xf…...

GraalVM Native Image内存模型深度解构:从Class Initialization Order到Heap Snapshot Graph的7层映射关系图

第一章:GraalVM Native Image内存模型的理论基石与设计哲学GraalVM Native Image 的内存模型并非传统 JVM 堆内存的简单移植,而是基于静态分析与封闭世界假设(Closed World Assumption)重构的全新范式。它在编译期即确定所有可达类…...

GLM技术复盘:篇论文深度解读智谱模型家族菏

开发个什么Skill呢? 通过 Skill,我们可以将某些能力进行模块化封装,从而实现特定的工作流编排、专家领域知识沉淀以及各类工具的集成。 这里我打算来一次“套娃式”的实践:创建一个用于自动生成 Skill 的 Skill,一是用…...

FastAPI子应用挂载:别再让root_path坑你一夜卤

Julia(julialang.org)由Stefan Karpinski、Jeff Bezanson等在2009年创建,目标是融合Python的易用性、C的高性能、R的统计能力、Matlab的科学计算生态。 其核心设计哲学是: 高性能:编译型语言(JIT&#xf…...

AI时代的算法思维:大经典排序学习弥

引言 在现代软件开发中,性能始终是衡量应用质量的重要指标之一。无论是企业级应用、云服务还是桌面程序,性能优化都能显著提升用户体验、降低基础设施成本并增强系统的可扩展性。对于使用 C# 开发的应用程序而言,性能优化涉及多个层面&#x…...