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

csp信奥赛C++高频考点专项训练之贪心算法 --【删数问题】:删数问题

csp信奥赛C高频考点专项训练之贪心算法 --【删数问题】删数问题题目描述键盘输入一个高精度的正整数n nn不超过250 250250位去掉其中任意k kk个数字后剩下的数字按原左右次序将组成一个新的非负整数。编程对给定的n nn和k kk寻找一种方案使得剩下的数字组成的新数最小。输入格式输入两行正整数。第一行输入一个高精度的正整数n nn。第二行输入一个正整数k kk表示需要删除的数字个数。输出格式输出一个整数最后剩下的最小数。输入输出样例 1输入 1175438 4输出 113说明/提示用len ⁡ ( n ) \operatorname{len}(n)len(n)表示n nn的位数保证1 ≤ k len ⁡ ( n ) ≤ 250 1 \leq k \operatorname{len}(n) \leq 2501≤klen(n)≤250。注意去掉若干数字后剩下的数可以存在前导零而输出时不要输出前导零。思路分析直接贪心删除策略每次删除一个数字重复 k 次。具体思路如下循环 k 次每次删除一个数字目标是让剩下的数最小。寻找删除位置从左到右扫描数字串找到第一个满足n[j] n[j1]的位置 j即“下降点”。这个位置上的数字比它右边的数字大删除它可以减小高位数值。如果整个序列是非递减的即没有下降点则删除最后一个数字。删除操作用erase(p,1)删除找到的位置 p 上的字符。去除前导零删除完成后如果结果字符串长度大于1且开头是 ‘0’则循环删除开头的零。输出结果输出剩余字符串若全为零则输出一个“0”。代码实现#includebits/stdc.h// 万能头文件usingnamespacestd;string n;// 存储输入的高精度数字intk;// 需要删除的数字个数intmain(){cinnk;// 读入数字串和kfor(inti1;ik;i){// 重复删除k次intpn.size()-1;// 默认删除最后一个字符当序列非递减时for(intj0;jn.size()-2;j){// 从左到右扫描相邻两位if(n[j]n[j1]){// 找到第一个下降点左边大于右边pj;// 记录要删除的位置break;// 立即退出扫描}}n.erase(p,1);// 删除该位置的一个字符}// 去除前导零但至少保留一个数字防止全删后为空while(n.size()1n[0]0){n.erase(0,1);// 删除开头的0}coutnendl;// 输出结果return0;}功能分析输入高精度正整数n字符串形式长度≤250和正整数kk len(n)。处理流程重复 k 次删除操作每次找到第一个“左边右边”的位置并删除该左边数字若无下降点则删除末尾数字。删除完成后去掉所有前导零但若全部为零则保留一个“0”。输出删除 k 个数字后能得到的最小数字无前导零。正确性基于贪心原理——每次删除第一个下降点能保证当前步最优最终结果全局最优。时间复杂度O(k·len)在题目限制下len≤250完全可接受。空间复杂度O(len)仅使用原字符串和几个变量。各种学习资料助力大家一站式学习和提升#includebits/stdc.husingnamespacestd;intmain(){cout########## 一站式掌握信奥赛知识! ##########;cout############# 冲刺信奥赛拿奖! #############;cout###### 课程购买后永久学习不受限制! ######;return0;}【秘籍汇总】完整csp信奥赛C学习资料1、csp/信奥赛C完整信奥赛系列课程永久学习https://edu.csdn.net/lecturer/7901 点击跳转2、CSP信奥赛C竞赛拿奖视频课https://edu.csdn.net/course/detail/40437 点击跳转https://edu.csdn.net/course/detail/41081 点击跳转3、csp信奥赛高频考点知识详解及案例实践CSP信奥赛C动态规划https://blog.csdn.net/weixin_66461496/category_13096895.html点击跳转CSP信奥赛C标准模板库STLhttps://blog.csdn.net/weixin_66461496/category_13108077.html 点击跳转信奥赛C提高组csp-s知识详解及案例实践https://blog.csdn.net/weixin_66461496/category_13113932.html 点击跳转4、csp信奥赛冲刺一等奖有效刷题题解CSP信奥赛C初赛及复赛高频考点真题解析持续更新https://blog.csdn.net/weixin_66461496/category_12808781.html 点击跳转信奥赛C提高组csp-s初赛复赛真题题解持续更新https://blog.csdn.net/weixin_66461496/category_13125089.html 点击跳转5、GESP C考级真题题解GESP(C 一级二级三级)真题题解持续更新https://blog.csdn.net/weixin_66461496/category_12858102.html 点击跳转GESP(C 四级五级六级)真题题解持续更新https://blog.csdn.net/weixin_66461496/category_12869848.html 点击跳转GESP(C 七级八级)真题题解持续更新https://blog.csdn.net/weixin_66461496/category_13117178.html 点击跳转· 文末祝福 ·#includebits/stdc.husingnamespacestd;intmain(){cout跟着王老师一起学习信奥赛C;cout 成就更好的自己 ;cout csp信奥赛一等奖属于你! ;return0;}

相关文章:

csp信奥赛C++高频考点专项训练之贪心算法 --【删数问题】:删数问题

csp信奥赛C高频考点专项训练之贪心算法 --【删数问题】:删数问题 题目描述 键盘输入一个高精度的正整数 nnn(不超过 250250250 位),去掉其中任意 kkk 个数字后剩下的数字按原左右次序将组成一个新的非负整数。编程对给定的 nnn 和…...

神经网络联合建模:分类与回归任务的高效解决方案

1. 神经网络在分类与回归联合任务中的应用价值在真实业务场景中,我们常常遇到需要同时预测离散类别和连续数值的问题。比如电商平台既要判断用户是否会点击商品(分类),又要预估点击后的停留时长(回归)&…...

深度解析:wxauto微信自动化框架的架构设计与实现原理

深度解析:wxauto微信自动化框架的架构设计与实现原理 【免费下载链接】wxauto Windows版本微信客户端(非网页版)自动化,可实现简单的发送、接收微信消息,简单微信机器人 项目地址: https://gitcode.com/gh_mirrors/w…...

DXVK 2.7.1:如何实现Linux游戏性能的终极突破与Vulkan图形转换技术

DXVK 2.7.1:如何实现Linux游戏性能的终极突破与Vulkan图形转换技术 【免费下载链接】dxvk Vulkan-based implementation of D3D8, 9, 10 and 11 for Linux / Wine 项目地址: https://gitcode.com/gh_mirrors/dx/dxvk 在Linux平台上运行Windows游戏一直面临着…...

游戏服务器分布式架构实战:cellmesh框架核心原理与应用

1. 项目概述:一个为游戏而生的分布式服务框架如果你在游戏服务器开发领域摸爬滚打过几年,大概率会对“服务拆分”和“通信治理”这两个词又爱又恨。爱的是,当你的在线玩家从几百人增长到几十万、上百万时,单体服务器架构必然崩溃&…...

SDF 文件深度解析

从格式解读到反标注实战,一文搞懂时序仿真的灵魂文件| 数字后端工程师必读 | STA & GLS 实战 | 避坑指南 |01 你的门级仿真,有没有踩过这些坑?做了几年芯片,最怕的不是综合报warning,也不是PR跑不完——而是门级仿…...

VSCode 2026远程文件同步提速412%:实测SSHFS+Rsync+DeltaFS三引擎协同优化方案

更多请点击: https://intelliparadigm.com 第一章:VSCode 2026远程文件同步提速412%:核心突破与技术背景 VSCode 2026 引入全新自适应增量同步引擎(AISE),彻底重构 Remote-SSH 和 Dev Containers 的文件同…...

nodejs 下国内最流行的框架

在国内企业、互联网公司、中小项目中,Node.js 最主流、使用最广泛的框架是:Express 和 NestJS,二者分属不同场景,占据绝对主导地位。一、按场景划分的主流排名1. 老牌通用王者:Express地位:国内最普及、生态…...

VCAM虚拟摄像头:安卓Xposed框架下的终极摄像头替换解决方案

VCAM虚拟摄像头:安卓Xposed框架下的终极摄像头替换解决方案 【免费下载链接】com.example.vcam 虚拟摄像头 virtual camera 项目地址: https://gitcode.com/gh_mirrors/co/com.example.vcam 在移动应用开发和内容创作领域,摄像头功能的重要性不言…...

缠论量化分析终极秘籍:从理论到实战的完整智能化解决方案

缠论量化分析终极秘籍:从理论到实战的完整智能化解决方案 【免费下载链接】Indicator 通达信缠论可视化分析插件 项目地址: https://gitcode.com/gh_mirrors/ind/Indicator 在金融市场的波动中,技术分析工具的质量直接影响着交易决策的精准度。今…...

字节开源trae-agent:Rust构建的高性能服务网格数据平面解析

1. 项目概述:一个现代服务网格数据平面的诞生最近在梳理服务网格生态时,我注意到了字节跳动开源的trae-agent。这个名字乍一看有点陌生,不像Envoy、Linkerd-proxy那样如雷贯耳,但深入了解后,我发现它代表了一种非常务实…...

AI老照片修复:Stable Diffusion技术实践与伦理考量

1. 老照片修复的艺术与技术挑战老照片承载着历史的记忆,但时间的流逝往往让这些珍贵的影像变得模糊、褪色甚至破损。作为一名长期从事数字影像修复的从业者,我深知传统修复方法需要耗费大量时间精力——在Photoshop中手动修复一张严重破损的照片可能需要…...

[嵌入式系统-267]:同一个型号的舵机如何支持Teacher模式和Student模式?如何设置?

在机械臂的“主从控制”(Teacher-Student)系统中,同一个型号的舵机完全可以同时支持两种模式。核心原理在于:模式不是由舵机硬件决定的,而是由控制器(主控板)赋予它的“角色”决定的。这就好比同…...

[嵌入式系统-266]:嵌入式系统软件常见十大难题与排查方法

在嵌入式开发中,我们常说“硬件是躯体,软件是灵魂”,但当灵魂出窍(程序跑飞)或者躯体僵硬(死机)时,排查工作往往令人头秃。结合最新的行业实战经验和经典理论,为你梳理了…...

[嵌入式系统-265]:什么是函数的可重入、什么是线程安全函数、什么是中断安全,举例说明

这三个概念是嵌入式和多线程编程中的基石,它们之间存在着严格的包含和递进关系。简单来说,它们的核心区别在于“在什么环境下被意外打断”以及“如何保护共享资源”。我们可以用一个形象的比喻来开场:可重入函数:像一个独行侠。他…...

从零实现C/C++内存管理库:轻量级内存泄漏检测与调试实践

1. 项目概述:一个极简内存管理库的诞生最近在整理一些C/C的老项目,发现很多代码里都散落着各种malloc和free,偶尔夹杂着new和delete。调试内存泄漏、野指针问题简直是一场噩梦,尤其是当项目规模稍大,或者多人协作时&am…...

深入解析Nuxt 3中的图标使用

在使用Nuxt 3开发应用时,图标的管理和使用是一个常见且关键的问题。本文将通过一个实际的例子,深入探讨如何在Nuxt 3应用中有效地管理和使用图标。 背景介绍 我们假设有一个Nuxt 3应用,采用了NuxtUI作为UI框架。为了避免图标名称的拼写错误和重复引用,我们创建了一个工具…...

基于PPO与CNN的DoomNet:从像素输入到游戏AI的深度强化学习实战

1. 项目概述:DoomNet,一个基于像素的强化学习智能体如果你对游戏AI或者深度强化学习感兴趣,那你大概率听说过DeepMind的Atari游戏AI,或者OpenAI的Dota 2智能体。这些项目通常需要庞大的计算资源和复杂的工程架构。今天我想分享一个…...

量子开发者的VSCode生死线,2026语法高亮失效?立即检测这4个隐藏配置项,错过将影响QPU编译精度!

更多请点击: https://intelliparadigm.com 第一章:量子开发者的VSCode生死线,2026语法高亮失效?立即检测这4个隐藏配置项,错过将影响QPU编译精度! 量子编程环境正经历一场静默崩溃:自2026年QDK…...

【VSCode 2026农业可视化插件首发指南】:5大核心能力+3类真实农田数据落地案例,仅限首批内测开发者获取

更多请点击: https://kaifayun.com 第一章:VSCode 2026农业可视化插件发布背景与核心定位 随着智慧农业加速落地,田间传感器、无人机遥感、气象站及IoT边缘设备每日产生TB级时空数据,但开发者长期受限于专业GIS工具门槛高、轻量级…...

机器学习算法核心六问:从原理到实战

1. 算法认知的六个黄金问题第一次接触机器学习算法时,我常被各种数学符号和术语淹没。直到导师告诉我:"任何算法本质上都是在回答六个核心问题。"这套方法帮我节省了数百小时的学习时间,现在我把这套方法论拆解给你。这六个问题就像…...

字节面试被问“Claude Code怎么做搜索”?答RAG后就没后续了

最近和在社区看到,有个求职者面试字节的时候,聊到了一些rag相关问题,正好这个求职者就说自己用过claude写代码,面试官就问他:那你知道Claude Code检索代码用的是什么方式吗?他说是RAG吧,现在不都…...

基于MCP协议的EVM区块链交互服务器:为AI智能体赋能Web3操作

1. 项目概述:为AI智能体打开区块链世界的大门 如果你正在构建一个AI智能体,并且希望它能像人类开发者一样,自由地查询以太坊上的余额、读取智能合约的状态,甚至帮你执行一笔代币转账,那么你很可能需要一个桥梁来连接A…...

RAG 实战:给 AI 接上私有知识库的完整方案

上一篇我们聊了 Agent 动态路由——任务交接时怎么把控流向。这次换个方向,聊一个大家问得最多的问题:怎么让 AI 能回答你自己公司的文档、产品手册、内部 Wiki? 你可能试过直接把文档塞进 System Prompt,结果 token 超限了。你也…...

ARM CP15协处理器架构与缓存控制技术详解

1. ARM CP15协处理器架构解析在ARMv7架构中,CP15协处理器承担着系统控制的核心职能。作为特权模式下才能访问的硬件模块,它通过一组专用寄存器实现对内存管理单元(MMU)、缓存子系统、TLB等关键组件的精细控制。与通用寄存器不同&a…...

小米手表表盘设计终极指南:用Mi-Create打造你的专属表盘

小米手表表盘设计终极指南:用Mi-Create打造你的专属表盘 【免费下载链接】Mi-Create Unofficial watchface creator for Xiaomi wearables ~2021 and above 项目地址: https://gitcode.com/gh_mirrors/mi/Mi-Create 还在为小米手表找不到心仪的表盘而烦恼吗&…...

光伏组件封装产线自动化通讯方案:三菱A系列PLC以太网多节点互联案例

一、行业背景与项目概况1.1 光伏行业技术需求光伏产业是实现“双碳”目标的核心支撑,光伏组件封装产线需实现电池片焊接、层压、裁切、检测等工序的高度自动化与数据互联互通,核心诉求涵盖设备协同联动、数据实时采集、远程运维效率提升,以保…...

我与AI的对话:当教科书思维撞上第一性原理 关于机器学习

一次让我重新思考“正确”的对话最近,我和AI进行了一次对话。起初我只是随口做了一个类比:“无监督学习和监督学习的分类,就像深度学习和机器学习一样。”AI立刻纠正我:这个类比不准确。它解释说,监督/无监督是按“是否…...

大模型API缓存的底层原理:从显存到网关

一、一个直觉引发的思考最近和一位朋友聊到API的缓存,他提出了一个很敏锐的问题:“其实tokens缓存都是假的吧?LLM本身就是无状态的。这种缓存只是一种计费规则。实际上跟上下文显存空间有关,你来用,他那边就会给你开一…...

一种通用的前端复刻思路:提取 UI 结构数据,交给 AI 生成代码

有时需要复刻一个已有的界面——可能是某个网页、一个 App 页面,或者微信小程序。传统做法是对着截图手动写代码,费时且还原度不稳定。最近试了一种方式:先把目标界面的 UI 结构数据提取出来,同时截一张高清截图,两者一…...