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

大学生网站建设课程总结Windows怎么建设网站

大学生网站建设课程总结,Windows怎么建设网站,网站建设背景介绍,网站建设都有哪些蓝桥杯2022年第十三届决赛真题-最大数字 时间限制: 3s 内存限制: 320MB 题目描述 给定一个正整数 N。你可以对 N 的任意一位数字执行任意次以下 2 种操作: 将该位数字加 1。如果该位数字已经是 9,加 1 之后变成 0。 将该位数字减 1。如果该位数字已经…

蓝桥杯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.yayakq.cn/news/926740/

相关文章:

  • 找设计方案的网站百度网站优化指南
  • 我的家乡网站建设网站规划设计内容有哪些
  • 如何自己建网站服务器wordpress 禁止修订版本
  • 重庆网页开发上海牛巨微seo
  • 江西省网站建设公司网页建设与网站设计
  • 优质公司网站小程序vr全景组件
  • 网络推广发帖网站网站建设祥云平台
  • 随州制作网站保定网站搜索引擎优化
  • 教学资源库网站建设立项申报书怎么免费的安装wordpress主题
  • jsp获取网站域名互联网公司排名 2022
  • wordpress站点预览重庆专业网站建设公司
  • 唐山网站提升排名php图片怎么导入wordpress
  • 如何做镜像别人网站国内免备案网站空间
  • 柳城企业网站建设价格学c++哪个线上机构好
  • 微信公众号网站开发注意wordpress全自动淘宝客
  • 乐平网站建设咨询wordpress 防黑
  • 重庆网站空间主机评价温州最好的seo
  • 企业网站建设管理视频软文发布平台哪家好
  • 苏州木渎做网站青田县建设局网站
  • 做网站f12的用处软件界面设计的原则
  • 游戏开发需要的软件百度快速seo软件
  • asp网站模板源码免费无限下载网络营销推广难做吗
  • 做中医药网站有前景吗wordpress模板主题介绍
  • 简单做动画的网站哈尔滨的建设信息网站
  • 网站内容由什么组成部分小米手机如何做游戏视频网站
  • 郴州做网站 郴网互联没有网站如何做营销
  • 中国建设电工立网站腾讯云域名交易
  • 南昌盗网站少优化公司易书网上书城网站建设方案
  • 自助建站最好的平台长沙企业关键词优化哪家好
  • 无锡本地模板网站建设产品甘肃省兰州市建设厅网站