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

第十四届蓝桥杯编程题部分代码题解

C. 冶炼金属

最大值就是取 a/ba / ba/b 的最小值,最小值就是二分找到满足 mid∗(bi+1)≥aimid * (b_i + 1) ≥ a_imid(bi+1)ai 的最小值

#include<bits/stdc++.h>
#define int long long
#define x first
#define y second
using namespace std;void solve()
{int n;cin >> n;vector<pair<int, int>> a(n);for (int i = 0; i < n; i++) cin >> a[i].x >> a[i].y;int l = 0, r = 1e9;auto check = [&](int mid){for (int i = 0; i < n; i++)if (mid * (a[i].y + 1) <= a[i].x) return false;return true;};while (l < r){int mid = l + r >> 1;if (check(mid)) r = mid;else l = mid + 1;}cout << l << ' ';int minn = 1e9;for (int i = 0; i < n; i++)minn = min(minn, a[i].x / a[i].y);cout << minn << '\n';
}signed main()
{// freopen("Sample.in", "r", stdin);ios::sync_with_stdio(false);cin.tie(0);int T = 1;// cin >> T;while (T--) solve();// cout << "Time:" << (double)clock() / 1000 << '\n';return 0;
}

D. 飞机降落

全排列枚举所有降落方案,然后判断即可

#include<bits/stdc++.h>
#define int long long
#define x first
#define y second
using namespace std;void solve()
{int n;cin >> n;vector<int> t(n + 10), d(n + 10), l(n + 10);for (int i = 0; i < n; i++) cin >> t[i] >> d[i] >> l[i];vector<int> p(n);for (int i = 0; i < n; i++) p[i] = i;do {int tt = 0;bool flag = true;for (int i = 0; i < n; i++){int x = p[i];if (tt > t[x] + d[x]){flag = false;break;}tt = max(tt, t[x]);tt += l[x];}if (flag) {cout << "YES" << '\n';return;}} while (next_permutation(p.begin(), p.end()));cout << "NO" << '\n';
}signed main()
{// freopen("Sample.in", "r", stdin);ios::sync_with_stdio(false);cin.tie(0);int T = 1;cin >> T;while (T--) solve();// cout << "Time:" << (double)clock() / 1000 << '\n';return 0;
}

E. 接龙数列

状态定义:f[i,j]f[i, j]f[i,j] 为前 iii 个数,以 jjj 结尾的最长合法子序列,答案就是 n−maxn - maxnmax

#include<bits/stdc++.h>
#define int long long
#define x first
#define y second
using namespace std;void solve()
{int n;cin >> n;map<int, int> mp;vector<int> a(n);vector<pair<int, int>> b(n);for (int i = 0; i < n; i++) cin >> a[i];for (int i = 0; i < n; i++){b[i].y = a[i] % 10;int x = a[i];while (x >= 10) x /= 10;b[i].x = x;}int ans = 0;for (int i = 0; i < n; i++){int x = mp[b[i].x];mp[b[i].y] = max(mp[b[i].y], x + 1);ans = max(ans, mp[b[i].y]);}cout << n - ans << '\n';
}signed main()
{// freopen("Sample.in", "r", stdin);ios::sync_with_stdio(false);cin.tie(0);int T = 1;// cin >> T;while (T--) solve();// cout << "Time:" << (double)clock() / 1000 << '\n';return 0;
}

F. 岛屿个数

考场上没什么思路,随便写了个Flood Fill就润了

G. 字串简写

处理 bbb 的前缀和,然后扫一遍即可

#include<bits/stdc++.h>
#define int long long
#define x first
#define y second
using namespace std;void solve()
{int k;cin >> k;string s;char a, b;cin >> s >> a >> b;int n = s.size();s = " " + s;vector<int> B(n + 10);for (int i = 1; i <= n; i++)if (s[i] == b) B[i] ++;for (int i = 1; i <= n; i++) B[i] += B[i - 1];int ans = 0;for (int i = 1; i <= n; i++){if (s[i] == a){if (i + k - 1 > n) continue;ans += B[n] - B[i + k - 2];}}cout << ans << '\n';
}signed main()
{// freopen("Sample.in", "r", stdin);ios::sync_with_stdio(false);cin.tie(0);int T = 1;// cin >> T;while (T--) solve();// cout << "Time:" << (double)clock() / 1000 << '\n';return 0;
}

H. 整数删除

首先初始化下每个数的前驱和后继

开一个小根堆,把所有数的大小和位置都放进去

每次循环,拿到数组中最小的数,标记上位置,然后操作它和它的前驱后继

但是可能拿到的数,已经被改变过了,所以我们需要开一个 mapmapmap ,记录下每个位置被改变过多少次

最后把没有被标记的数输出即可

#include<bits/stdc++.h>
#define int long long
#define x first
#define y second
using namespace std;void solve()
{int n, k;cin >> n >> k;vector<int> a(n + 10);for (int i = 1; i <= n; i++) cin >> a[i];vector<pair<int, int>> b(n + 10);for (int i = 1; i <= n; i++) b[i] = {i - 1, i + 1};priority_queue<pair<int, int>, vector<pair<int, int>>, greater<pair<int, int>>> heap;for (int i = 1; i <= n; i++) heap.push({a[i], i});map<int, int> mp;vector<bool> st(n + 10);for (int i = 0; i < k; i++){while (mp[heap.top().y]){mp[heap.top().y] --;heap.pop();}auto t = heap.top();heap.pop();st[t.y] = true;int l = b[t.y].x, r = b[t.y].y;b[l].y = r, b[r].x = l;a[l] += t.x, a[r] += t.x;mp[l] ++, mp[r] ++;if (l) heap.push({a[l], l});if (r <= n) heap.push({a[r], r});}for (int i = 1; i <= n; i++)if (!st[i]) cout << a[i] << ' ';
}signed main()
{// freopen("Sample.in", "r", stdin);ios::sync_with_stdio(false);cin.tie(0);int T = 1;// cin >> T;while (T--) solve();// cout << "Time:" << (double)clock() / 1000 << '\n';return 0;
}

写在最后

剩下两题都是LCA好像,不太会,导游暴力Floyd骗分,最后一题没读完题,输出样例后就选择去检查了,上述几题都过了民间数据了,应该问题不大,很好啊,好像省一稳了?噢,原来有人赛时没开long long没关同步流啊,为什么没呢?很简单啊,怕过不了编译,然后就真忘了,我是傻逼

相关文章:

第十四届蓝桥杯编程题部分代码题解

C. 冶炼金属 最大值就是取 a/ba / ba/b 的最小值&#xff0c;最小值就是二分找到满足 mid∗(bi1)≥aimid * (b_i 1) ≥ a_imid∗(bi​1)≥ai​ 的最小值 #include<bits/stdc.h> #define int long long #define x first #define y second using namespace std;void sol…...

统一结果封装异常处理

统一结果封装&异常处理2&#xff0c;统一结果封装2.1 表现层与前端数据传输协议定义2.2 表现层与前端数据传输协议实现2.2.1 环境准备2.2.2 结果封装步骤1:创建Result类步骤2:定义返回码Code类步骤3:修改Controller类的返回值步骤4:启动服务测试3&#xff0c;统一异常处理3…...

数字藏品平台的发展趋势是什么?

1、数字藏品平台具体内容生产模式将在PGC&#xff08;专业生产制造具体内容&#xff09;方式向PUGC&#xff08;技术专业用户生产内容&#xff09;方式变化。 目前&#xff0c;中国热门的数字藏品平台都在PGC模式中持续发展的&#xff0c;而国外流行NFT平台则比较多选用UGC&am…...

Vue3对话框(Dialog)

Vue2对话框&#xff08;Dialog&#xff09; 可自定义设置以下属性&#xff1a; 标题&#xff08;title&#xff09;&#xff0c;类型&#xff1a;string | slot&#xff0c;默认 提示 内容&#xff08;content&#xff09;&#xff0c;类型&#xff1a;string | slot&#xf…...

【深度强化学习】(5) DDPG 模型解析,附Pytorch完整代码

大家好&#xff0c;今天和各位分享一下深度确定性策略梯度算法 (Deterministic Policy Gradient&#xff0c;DDPG)。并基于 OpenAI 的 gym 环境完成一个小游戏。完整代码在我的 GitHub 中获得&#xff1a; https://github.com/LiSir-HIT/Reinforcement-Learning/tree/main/Mod…...

unity,Color.Lerp函数

介绍 Color.Lerp函数是Unity引擎中的一个静态函数&#xff0c;用于在两个颜色值之间进行线性插值&#xff0c;从而实现颜色渐变效果 方法 Color.Lerp函数是Unity引擎中的一个静态函数&#xff0c;用于在两个颜色值之间进行线性插值&#xff0c;从而实现颜色渐变效果。该函数的…...

洛谷P8799 [蓝桥杯 2022 国 B] 齿轮 C语言/C++

[蓝桥杯 2022 国 B] 齿轮 题目描述 这天&#xff0c;小明在组装齿轮。 他一共有 nnn 个齿轮&#xff0c;第 iii 个齿轮的半径为 rir_{i}ri​, 他需要把这 nnn 个齿轮按一定顺序从左到右组装起来&#xff0c;这样最左边的齿轮转起来之后&#xff0c;可以传递到最右边的齿轮&a…...

景区在线售票系统功能开发介绍

目前游客线上订票已经普及&#xff0c;景区开通线上购票渠道&#xff0c;方便游客购票&#xff0c;对于还没有开通线上购票的景区来说&#xff0c;需要提前了解一下景区线上售票系统的一些功能&#xff0c;下面给大家详细介绍一下景区在线售票需要哪些功能。 1、在线售票 包含门…...

webService的底层调用方式

webservice中采用协议Http&#xff0c;是指什么意思 WebService使用的是 SOAP (Simple Object Access Protocol)协议 Soap协议只是用来封装消息用的。封装后的消息你可以通过各种已有的协议来传输&#xff0c;比如http,tcp/ip,smtp,等等&#xff0c;你甚至还一次用自定义的协议…...

关于文件的一些小知识下

&#x1f34d;个人主页&#x1f34d;:&#x1f51c;勇敢的小牛儿&#x1f6a9; &#x1f531;推荐专栏&#x1f531;&#xff1a;C语言知识点 ⚠️座右铭⚠️&#xff1a;敢于尝试才有机会 &#x1f412;今日鸡汤&#x1f412;&#xff1a; 你受的苦 吃的亏 担的责 扛的罪 忍的…...

使用Cheat Engine与DnSpy破解Unity游戏

题目连接&#xff1a; https://play.picoctf.org/practice/challenge/361?originalEvent72&page3我们是windows系统&#xff0c;所以点击windows game下载游戏 双击运行pico.exe 屏幕上方的一串英文是叫我们找flag&#xff0c;我在这个小地图里走来走去也没flag&#xff…...

溯源取证-内存取证基础篇

使用工具&#xff1a; volatility_2.6_lin64_standalone 镜像文件&#xff1a; CYBERDEF-567078-20230213-171333.raw 使用环境&#xff1a; kali linux 2022.02 我们只有一个RAW映像文件&#xff0c;如何从该映像文件中提取出我们想要的东西呢&#xff1f; 1.Which volatili…...

Leetcode.100 相同的树

题目链接 Leetcode.100 相同的树 easy 题目描述 给你两棵二叉树的根节点 p和 q&#xff0c;编写一个函数来检验这两棵树是否相同。 如果两个树在结构上相同&#xff0c;并且节点具有相同的值&#xff0c;则认为它们是相同的。 示例 1&#xff1a; 输入&#xff1a;p [1,2,3…...

每个程序员都应该知道的8大算法

在编程开发中&#xff0c;算法是用于解决特定问题或完成特定任务的一组指令或过程。算法可以用任何编程语言表示&#xff0c;可以像一系列基本操作一样简单&#xff0c;也可以像涉及不同数据结构和逻辑的多步骤过程一样复杂。 算法的主要目标是接收输入、处理它并提供预期的输…...

Nestjs实战超干货-概况-模块-Modules

模块 模块就是一个声明了装饰器Module()的类。装饰器Module()提供了元数据&#xff0c;以便让Nest组织应用程序结构。 每个应用程序至少有一个模块&#xff0c;即根模块。根模块是 Nest 用来构建应用程序图的起点&#xff0c;应用程序图是 Nest 用来解析模块和提供者关系和依赖…...

template

模板 模板注意事项 模板的函数体和声明一定要在一起&#xff0c;即放在同一个.h文件中&#xff0c;而不能将其分开到cpp和h文件中模板的编译技巧就是尽量多编译&#xff0c;模板很难查找错误模板的报错一般只有第一行有作用模板指定类型从左到右依次指定 模板推导 #pragma #…...

innovus中时序路径debug及命令使用详解?

写在前面&#xff1a;发现place结果所有与outport相关的timing check都找不到&#xff1f; 刚开始怀疑是sdc约束问题&#xff0c;check了input sdc文件及enc.dat/mmmc/mode/func.sdc 看一下是否设置了set_false_path.当然也可以用命令报出来: report_timing -unconstrained …...

C语言爱心代码大全集—会Ctrl+C就可以表白了

一、C语言爱心代码大全&#xff0c;会CtrlC就可以表白了&#xff01; 博主整理了一个C语言爱心代码大全&#xff0c;里面有C语言爱心代码会动的动态效果和C语言爱心代码大全静态效果&#xff0c;只需复制粘贴就可以用啦&#xff01; 1、动态C语言爱心代码效果图如下&#xff…...

python+vue+django耕地信息管理系统的设计与实现

基普通用户模块含有个人中心、耕地信息管理、转让许可申请管理、租赁许可申请管理等功能&#xff1b;普通管理员模块含有个人中心、用户管理、公示公告管理、耕地信息管理、耕地信息统计、转让许可申请管理、租赁许可申请管理、转让协议管理、租赁协议管理等功能&#xff1b;管…...

【云原生】Dockerfile制作WordPress镜像,实现compose编排部署

文章目录&#x1f479; 关于作者前言环境准备目录结构dockerfile制作镜像yum 脚本Dockerfile-mariadb 镜像Dockerfile-service 镜像docker compose 编排提升✊ 最后&#x1f479; 关于作者 大家好&#xff0c;我是秋意临。 &#x1f608; CSDN作者主页 &#x1f60e; 博客主页…...

量子计算在流体动力学中的创新应用:PolyQROM技术解析

1. 量子计算与流体动力学&#xff1a;PolyQROM的创新突破在计算流体力学&#xff08;CFD&#xff09;领域&#xff0c;高精度模拟一直是科研和工程实践的圣杯。传统基于Navier-Stokes方程的数值模拟&#xff0c;其计算复杂度随雷诺数呈立方级增长&#xff0c;使得高雷诺数流动的…...

探索物联网通信新高度:STM32 MQTT协议功能实现

探索物联网通信新高度&#xff1a;STM32 MQTT协议功能实现 【下载地址】STM32MQTT协议功能实现分享 本仓库提供了一个资源文件&#xff0c;标题为“STM32 MQTT协议功能实现”。该资源文件包含了使用C语言实现的MQTT协议客户端功能&#xff0c;并且已经成功移植到STM32平台上。经…...

LLM实战指南:从Transformer原理到微调部署的完整学习路径

1. 项目概述&#xff1a;一个面向实践者的LLM学习路线图最近在GitHub上看到一个叫mlabonne/llm-course的项目&#xff0c;热度非常高。点进去一看&#xff0c;这其实不是一个传统意义上的“课程”&#xff0c;而更像一份由社区驱动的、持续更新的“大型语言模型实战指南”。它的…...

C#上位机与三菱PLC通信实战:从零构建GX Works3仿真平台

1. 为什么需要搭建GX Works3仿真平台 第一次接触三菱PLC开发的朋友们&#xff0c;可能都有这样的困惑&#xff1a;手头没有实体PLC设备&#xff0c;怎么测试自己写的控制程序&#xff1f;买一台FX5U PLC动辄几千元&#xff0c;对个人开发者来说成本太高。这时候仿真平台就成了最…...

NVIDIA Profile Inspector终极指南:轻松解锁显卡隐藏性能的免费工具

NVIDIA Profile Inspector终极指南&#xff1a;轻松解锁显卡隐藏性能的免费工具 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector 还在为游戏卡顿、画面撕裂而烦恼&#xff1f;想要彻底掌控显卡性能却找不…...

新手教程使用Python快速接入Taotoken调用多款大模型

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 新手教程使用Python快速接入Taotoken调用多款大模型 对于刚接触大模型API的开发者而言&#xff0c;直接对接不同厂商的API往往意味…...

基于ARM嵌入式平台与AI视觉的输电线路智能巡检系统设计与实现

1. 项目概述&#xff1a;输电线路巡检的智能化转型 输电线路作为电力系统的“大动脉”&#xff0c;其安全稳定运行至关重要。传统的线路巡检主要依赖人工&#xff0c;巡检人员需要跋山涉水&#xff0c;通过望远镜、红外测温仪等设备进行观测和记录。这种方式不仅劳动强度大、效…...

共享茶室智能系统与运营全解析:从空间设计到自动化管理

1. 项目概述&#xff1a;为什么“共享茶室”正在重塑传统茶饮消费如果你最近留意过城市里的新业态&#xff0c;可能会发现一种名为“共享茶室”的空间正在悄然兴起。它不像传统的茶馆那样需要高昂的消费和复杂的社交礼仪&#xff0c;也不像奶茶店那样主打快节奏的“即买即走”。…...

英雄联盟LCU自动化工具:3步打造你的专属智能游戏伴侣

英雄联盟LCU自动化工具&#xff1a;3步打造你的专属智能游戏伴侣 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power &#x1f680;. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 还在为英雄联盟中重复繁琐的操…...

Netscape 浏览器:互联网时代的先驱者

Netscape 浏览器:互联网时代的先驱者 引言 自互联网诞生以来,浏览器作为连接用户与网络世界的重要工具,见证了互联网的飞速发展。在众多浏览器中,Netscape 浏览器以其创新和引领潮流的特性,成为了互联网时代的先驱者。本文将回顾 Netscape 浏览器的发展历程、技术特点及…...