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

蓝桥杯2022年第十三届决赛真题-最大数字

蓝桥杯2022年第十三届决赛真题-最大数字

时间限制: 3s 内存限制: 320MB

题目描述

给定一个正整数 N。你可以对 N 的任意一位数字执行任意次以下 2 种操作:

  1. 将该位数字加 1。如果该位数字已经是 9,加 1 之后变成 0。

  2. 将该位数字减 1。如果该位数字已经是 0,减 1 之后变成 9。

你现在总共可以执行 1 号操作不超过 A 次,2 号操作不超过 B 次。

请问你最大可以将 N 变成多少?

输入格式

第一行包含 3 个整数:N, A, B。
输出格式
一个整数代表答案。

样例输入

123 1 2

样例输出

933

提示

对百位数字执行 2 次 2 号操作,对十位数字执行 1 次 1 号操作。

对于 30% 的数据,1 ≤ N ≤ 100; 0 ≤ A, B ≤ 10

对于 100% 的数据,1 ≤ N ≤ 1017; 0 ≤ A, B ≤ 100

题解

贪心法来观察题目可以分析出以下性质

  1. 对于某一位,加减操作不会混着用,即要么加操作、要么减操作

  2. 对于减操作,当且仅当能够将这一位减少到9,才会执行,否则答案会变差

  3. 对于加操作,只要有剩余就可以执行操作,并且一定是将其置为9

  4. 最终的值最大,所以需要从最高位来进行操作

  5. 假设当前值为x 每次操作使用+操作需要消耗掉9-x个a,使用-操作消耗10+x-9个b

  6. 由于不确定对某一位具体使用的+操作还是-操作,可以使用深度优先搜索,枚举所有情况

  7. 时间复杂度为O(218),还可以剪枝,跑的飞快

#include<bits/stdc++.h>
using namespace std;
int num[20];
int da[20], db[20];
typedef long long ll;
ll ans = 0;
int sz = 0;
void dfs(int now, int a, int b)
{   //统计答案if (now == -1 || (a == 0 && b == 0)){  ll tans = 0;for (int i = sz-1; i>=0; i--){tans *= 10; tans += num[i];}ans = max(ans, tans);return;}int t = num[now];num[now] += min(da[now], a);dfs(now - 1, max(a - da[now],0), b);num[now] = t;if (b >= db[now]){t = num[now];num[now] = 9;dfs(now - 1, a, b - db[now]);num[now] = t;}}
int main()
{ll N, a, b; cin >> N >> a >> b;while (N){num[sz++] = N % 10;N /= 10;}//预处理a、b每一位的消耗for (int i = 0; i < sz; i++){da[i] = 9 - num[i];db[i] = num[i]+1;}dfs(sz - 1, a, b); cout << ans << endl;
}

码量更小的写法

#include <bits/stdc++.h>
#define int long long
using namespace std;
int n, a, b, res = 0, bit = 1;
//now,x,y,f分别代表当前数字,剩余操作1数量,剩余操作2数量,当前考虑第几位 
void dfs(int now, int x, int y, int f)
{res = max(now, res);if (x == 0 && y == 0||f==0)return;int t = (now / f) % 10;//获取当前位的数字 if (x >= 9 - t)dfs(now + f * (9 - t), x - (9 - t), y, f / 10);//如果操作1可以变成9 else dfs(now + x * f, 0, y, f / 10);//不能变成9 if (y >= t + 1)dfs(now + f * (9 - t), x, y - (t +1), f / 10);//如果操作2可以变成9 
}
signed main()
{ios::sync_with_stdio(false);  cin.tie(0); cout.tie(0);cin >> n >> a >> b;while (n / bit >= 10)bit *= 10;//获取最高位的值 dfs(n, a, b, bit);cout << res;return 0;
}
http://www.lryc.cn/news/64450.html

相关文章:

  • smbms项目搭建
  • 进程/线程 状态模型详解
  • 数据结构与算法之队列: Leetcode 621. 任务调度器 (Typescript版)
  • 【报错】arXiv上传文章出现XXX.sty not found
  • 项目合同管理
  • 聊聊ClickHouse向量化执行引擎-过滤操作
  • 数据可视化第二版-拓展-网约车分析案例
  • pytest - Getting Start
  • ( 字符串) 205. 同构字符串 ——【Leetcode每日一题】
  • python+django+vue消防知识宣传网站
  • 彻底告别手动配置任务,魔改xxl-job!
  • 【五一创作】Springboot+多环境+多数据源(MySQL+Phoenix)配置及查询(多知识点)
  • Python小姿势 - 线程和进程:
  • Mysql 锁
  • 基于ssm的论坛系统的设计与实现【附源码】
  • Vue中的事件修饰符
  • 如何保证Redis和数据库的一致性
  • Ubantu docker学习笔记(八)私有仓库
  • 【五一创作】网络协议与攻击模拟-01-wireshark使用-捕获过滤器
  • 网络-IP地址(嵌入式学习)
  • 一文介绍Linux EAS
  • 【五一创作】【Midjourney】Midjourney 连续性人物创作 ① ( 通过垫图方式生成类似图像 )
  • 牛客刷题错题记录【03】
  • maven-gpg-plugin gpg禁用交互式输入密码 免密码输入 设置默认密码 关闭pinentry-qt输入 passphrase
  • 急需国产化替代的重要的工程软件有哪些?
  • 计算机组成原理 4.2.1存储芯片连接
  • 这份【互联网项目全流程表】,实在是泰裤辣!!!
  • JAVA医院管理云HIS统计报表子系统、系统管理字系统功能实现
  • 5.Java中抽象类和接口
  • 中国平安将在2023年出现转机,复苏才刚刚开始