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

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

蓝桥杯2022年第十三届决赛真题-最大数字
时间限制: 2s 内存限制: 320MB 提交: 5703 解决: 1321
题目描述
给定一个正整数 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.分析

        1.预处理出所有位数所需加和减的次数

        2.dfs找出最大的数。

        3.如果加法和减法都无法到9,那么只有加法是可用的。

2.代码

        

#include<iostream>
using namespace std;
typedef long long LL;
const int MAX = 1110;
string s,t;
int a, b;
int add[MAX], del[MAX];
string re="";
void check(int d,int x) {       //预处理
	add[d] = 9 - x;
	del[d] = x - 0 + 1;
}
void dfs(int d,int x,int y) {      //dfs
	if (x==0&&y==0) {            //判断
		if (re<s||re=="") {
			re = s;
		}
		return;
	}
	for (int i = d; i < s.size(); i++) {   //遍历
		if (s[i] == '9') continue;
		if (x >0) {
			if (x > add[i]) {            //可以加到9
				s[i] = '9';
				dfs(i + 1, x - add[i], y);
				s[i] = t[i];
			}
			else {                //可以加,但是不能加到9
				s[i] = t[i] - '0' + x + '0';
				dfs(i + 1, 0, y);
				s[i] = t[i];
			}

		}
		if (y >= del[i])
		{
			s[i] = '9';
			dfs(i + 1, x, y - del[i]);
			s[i] = t[i];
		}
	}
	if (s > re) {         //判断
		re = s;
	}
}
int main() {
	cin >> s >> a >> b;
	t = s;
	for (int i = 0; i < s.size(); i++) {
		check(i, s[i] - '0');
	}
	dfs(0,a,b);
	cout << re << endl;
	return 0;
}

相关文章:

  • Springboot 学习 之 Shardingsphere 按照日期水平分表(一)
  • Swift 二分法求函数的近似解
  • Ubuntu20.04系统安装IsaacSim4.5与IsaacLab环境
  • html和css 实现元素顺时针旋转效果(椭圆形旋转轨迹)
  • MongoDB 的索引是提高查询性能的核心机制,类似于传统关系型数据库的索引。以下是对 MongoDB 索引的详细说明:
  • 基础实验2-2.1 整数的分类处理
  • openresty-nginx添加新模块
  • 机器学习中的 K-均值聚类算法及其优缺点
  • 什么是Dify,以及我们能用它来做什么
  • 开源AI大模型赋能私域流量:S2B2C场景下品牌文化建构的智能路径研究
  • Micropython RPI-PICO 随记-双PICO串口传数据
  • VMware Workstation虚拟机固定IP配置(主机互通、外网可访问)
  • 【Windows计算机常识】查看IP配置
  • 热门面试题第14天|Leetcode 513找树左下角的值 112 113 路径总和 105 106 从中序与后序遍历序列构造二叉树 (及其扩展形式)以一敌二
  • 【深度学习】GAN生成对抗网络:原理、应用与发展
  • 理解Kubernetes中CoreDNS域名解析与DNS策略
  • 蓝桥杯备考----->Cow Picnic (BFS)
  • redis--JavaSpring客户端
  • Modbus协议详细规范
  • MySQL基础语法
  • centos wordpress 建站教程/谷歌搜索指数查询
  • 江苏省建设厅网站证件查询/河北百度seo
  • 天津房地产集团网站建设/自制网站
  • 电商网站开发背景/下载安装百度一下
  • 成都网站建设公司排名/东莞最新消息 今天
  • 外包公司做网站价格/网站seo的优化怎么做