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

柳州网站建设22全球网站排名查询

柳州网站建设22,全球网站排名查询,做流量网站要做哪一种,jsp系统网站建设带源代码嘿,各位技术潮人!好久不见甚是想念。生活就像一场奇妙冒险,而编程就是那把超酷的万能钥匙。此刻,阳光洒在键盘上,灵感在指尖跳跃,让我们抛开一切束缚,给平淡日子加点料,注入满满的pa…

嘿,各位技术潮人!好久不见甚是想念。生活就像一场奇妙冒险,而编程就是那把超酷的万能钥匙。此刻,阳光洒在键盘上,灵感在指尖跳跃,让我们抛开一切束缚,给平淡日子加点料,注入满满的passion。准备好和我一起冲进代码的奇幻宇宙了吗?Let's go!

我的博客:yuanManGan

我的专栏:C++入门小馆 C言雅韵集 数据结构漫游记  闲言碎语小记坊 题山采玉 领略算法真谛

今天的题全来自蓝桥杯国赛的题

2022P8803 [蓝桥杯 2022 国 B] 费用报销 - 洛谷

P8801 [蓝桥杯 2022 国 B] 最大数字 - 洛谷

出差

2022

签到题 

#include <iostream>
using namespace std;
int main()
{cout << "A C" << endl;cout << "A D" << endl;cout << "B D" << endl;return 0;
}

这道题就是一道01背包题,本次2022国赛有几道01背包的题目。

我们将2022看成1到2022个数,在里面选10个数,题目问加起来等于2022的方案数有多少个,我们来定义状态表示:

f[i][j][k]表示,从前i个数里面挑j个数其中和恰好等于k的个数

状态转移方程

选i位置 f[i][j][k] += f[i-1][j -1][k - i];

不选i位置 f[i][j][k] += f[i-1][j][k];

初始化将f[0][0][0] = 1;

填表顺序从上到下,从左到右。

最后结果:f[2022][10][2022]

#include <iostream>using namespace std;
typedef long long LL;
LL f[2023][11][2023];
int main()
{f[0][0][0] = 1;for (int i = 1; i <= 2022; i++){for (int j = 0; j <= 10; j++){for (int k = 0; k <= 2022; k++){f[i][j][k] += f[i - 1][j][k];if (j >= 1 && k >= i) f[i][j][k] += f[i - 1][j - 1][k - i];}}}cout << f[2022][10][2022] << endl;return 0;
}

我们进行一下空间优化

#include <iostream>using namespace std;
typedef long long LL;
LL f[11][2023];
int main()
{f[0][0] = 1;for (int i = 1; i <= 2022; i++)for (int j = 0; j <= 10; j++)for (int k = 0; k <= 2022; k++)if (j >= 1 && k >= i) f[j][k] += f[j - 1][k - i];cout << f[10][2022] << endl;return 0;
}

我们设最多能凑出y套卡牌

能使用最多m张空白卡牌

当我们使用的空白卡牌数越多,我们能凑出的卡牌套数就越多

明显的二段性

当y = mid时,算出的ret > m 时 r = mid - 1

当ret <= m时里面可以存在答案所以l = mid

就直接上代码了

#include <iostream>using namespace std;
const int N = 2e5 + 10;
typedef long long LL;
LL a[N], b[N];
LL n, m;
bool check(LL x)
{LL cnt = 0;for (int i = 1; i <= n; i++){if (a[i] + b[i] < x) return false;if (a[i] < x)cnt += (x - a[i]);if (cnt > m) return false;}return true;
}
int main()
{cin >> n >> m;LL l = 0, r = 0;for (int i = 1; i <= n; i++) cin >> a[i];for (int i = 1; i <= n; i++){cin >> b[i];r = max(r, b[i] + a[i]);}while (l < r){LL mid = (l + r + 1) / 2;if (check(mid)) l = mid;else r = mid - 1;}cout << l << endl;return 0;
}

我们一个小贪心是首先处理最高位,让最高位最大。

可以对每位数字进行加一或者减一的操作分别a,b次

我们先来分析一下减法操作:

对x做减法,要么就减到9要么就不减,比如将4减到9要先减四次减到0然后还得减一次

所以有要减:x + 1次操作。

那么加法呢

我们将x最好能加到9要进行几次操作,比如将5加到9要进行4次操作

所以加到9要用x次加法。

我们可以采用深搜来解决这个问题

#include <iostream>using namespace std;
typedef long long LL;
string s, ret;
LL n;
void dfs(LL pos, LL a, LL b, string s)
{if (pos == n){if (ret < s) ret = s;return;}LL up = '9' - s[pos], down = s[pos] - '0' + 1;if (up <= a || down <= b){s[pos] = '9';if(up <= a)dfs(pos + 1, a - up, b, s);if(down <= b)dfs(pos + 1, a, b - down, s);}else{s[pos] += a;dfs(pos + 1, 0, b, s);}}
int main()
{LL a, b;cin >> s >> a >> b;n = s.size();dfs(0, a, b, s);cout << ret << endl;return 0;
}

http://www.dtcms.com/wzjs/315314.html

相关文章:

  • 学校建设网站的作用最新新闻热点大事件
  • 橙子建站突然发验证码网络优化公司有哪些
  • 太原城市建设招标网站推广运营怎么做
  • 网站推广和seo市场推广和销售的区别
  • 中建卓越建设有限公司网站首页win11优化大师
  • 网站做中秋专题怎么弄企业qq和个人qq有什么区别
  • 江门市城乡建设局网站百度搜索推广收费标准
  • 部门网站建设管理典型经验材料百度的企业网站
  • 做房产网站需要了解什么东西靠谱seo外包定制
  • 专门做ppt背景的网站有哪些线上营销怎么推广
  • 西安网站架设公司全网霸屏推广系统
  • 网页设计个人简历代码北京seo优化wyhseo
  • 大连哪有做网站的打广告推广怎么做
  • 杭州网站设计步骤关键词排名批量查询软件
  • 网站建站商务平台搜索引擎营销的特点有
  • 网站建设私人接单平台电脑培训班有哪些科目
  • 做外挂网站空间今日新闻简讯30条
  • 上海影视传媒公司排名网站关键词优化
  • 陕西建设银行官网站模板建站难吗
  • 找公司做网站多少钱成都360广告推广平台
  • 公司网站建设的湖南好搜公司seo
  • 科技有限公司简介优化算法
  • .net 手机网站开发公众号关键词排名优化
  • 有专门做预算的网站没百度搜索量查询
  • 软件开发文档的作用优化网站怎么做
  • 做电商网站注意什么站内推广的方法
  • 买卖域名的网站好朋友圈产品推广文案
  • 网站图片优化大小搜索排名广告营销怎么做
  • 做阿里巴巴网站口碑西安网站seo工作室
  • seo搜索引擎优化网站seo同行网站