2023CCPC河南省赛暨河南邀请赛个人补题ABEFGHK

Dashboard - 2023 CCPC Henan Provincial Collegiate Programming Contest - Codeforces

过题难度:A H F G B K E

铜奖: 2  339

银奖: 3  318

金奖: 5  523

A:

直接模拟

// Code Start Here	int t;cin >> t;while(t--){string s;cin >> s;set<char> seen;bool found = false;		for (int i = 1; i < sz(s); ++i) {bool ok = true;seen.clear();for (int j = 0; j < i; ++j) {if (seen.count(s[j])) {ok = false;break;}seen.insert(s[j]);}if (!ok) continue;int l = i, r = sz(s) - 1;while (l < r) {if (s[l] != s[r]) {ok = false;break;}++l;--r;}if (ok) {found = true;break;}}cout << (found ? "HE\n" : "NaN\n");}

H

思路:我们发现0.5会进位,而距离0.5无穷左边就会被舍去,因此最小的方式是分出来的尽量距离0.5差一点点,最多的就是0.5

// Code Start Here	int t;cin >> t;while(t--){int n , k;cin >> n >> k;if(k > 2 * n)cout << 0 << " " << 2 * n <<endl;else{int minv = (2 * n - k + 2) / 2;int maxv = minv + k - 1;cout << minv << " " << maxv << endl;}}

F

题意:

给定一个数列A从中选出 k 个数,计算:这些数的最大值-最小值,记作 max。这些数相邻差值中的最小值,记作 min。要求使max×min 最小

思路:我们发现排序后,任意 k 个数如果不连续,选中其中的最大和最小值之差一定不会比连续的更小。同时,相邻差值的最小值如果跳着选,差值可能会变大,而连续的差值是最稳定的。

对于连续的 k 个数,max=A[i+k−1]−A[i]。假设有k−1 个相邻差值,存在差分数组 diff,使得diff[j]=A[j+1]−A[j]。连续区间 [i, i+k-1] 中,相邻差值的最小值就是min=min(diff[i],diff[i+1],...,diff[i+k−2])。

因此我们可以遍历所有可能的连续 k 个数区间,求:每个区间内max×min,然后取最小值

考虑到5e5的数据规模,我们使用单调队列维护区间内差值的最小值。在O(1) 时间内取当前窗口最小值,且在移动窗口时自动维护单调性,效率是O(n)。

// Code Start Here	int n , k;cin >> n >> k;vector<int> a(n);for(int i = 0;i<n;i++)cin >> a[i];sort(all(a));vector<int> diff(n-1);for(int i = 0;i<n-1;i++)diff[i] = a[i+1] - a[i];int ans =  1e18;deque<int> dq;for(int i = 0;i<n;i++){if(i > 0){while(!dq.empty() && diff[i-1] <= diff[dq.back()])dq.pop_back();dq.push_back(i - 1);}if(i >= k){if (!dq.empty() && dq.front() < i - k)dq.pop_front();}if(i >= k-1){int max_v = a[i] - a[i-k+1];int min_v = 1e9;if(k > 1 && !dq.empty() )min_v = diff[dq.front()];if(k == 1)min_v = 1e9;ans = min(ans , 1LL *max_v * min_v);}}cout << ans << endl;return 0;

G:

一道超级大模拟题,考虑到个体的特殊性,我们可以对底数和幂数分别开两个数组来映射,使用的时候取出即可

char a[][100] = {"",".................................................................................",".................................................................................",".0000000.......1.2222222.3333333.4.....4.5555555.6666666.7777777.8888888.9999999.",".0.....0.......1.......2.......3.4.....4.5.......6.............7.8.....8.9.....9.",".0.....0.......1.......2.......3.4.....4.5.......6.............7.8.....8.9.....9.",".0.....0.......1.2222222.3333333.4444444.5555555.6666666.......7.8888888.9999999.",".0.....0.......1.2.............3.......4.......5.6.....6.......7.8.....8.......9.",".0.....0.......1.2.............3.......4.......5.6.....6.......7.8.....8.......9.",".0000000.......1.2222222.3333333.......4.5555555.6666666.......7.8888888.9999999.",".................................................................................",
};char b[][100] = {"",".............................................................",".00000.....1.22222.33333.4...4.55555.66666.77777.88888.99999.",".0...0.....1.....2.....3.4...4.5.....6.........7.8...8.9...9.",".0...0.....1.22222.33333.44444.55555.66666.....7.88888.99999.",".0...0.....1.2.........3.....4.....5.6...6.....7.8...8.....9.",".00000.....1.22222.33333.....4.55555.66666.....7.88888.99999.",".............................................................",".............................................................",".............................................................",".............................................................",
};char c[][100] = {"",".................................",".................................",".........IIIIIII.N.....N.FFFFFFF.","............I....NN....N.F.......",".=======....I....N.N...N.F.......","............I....N..N..N.FFFFFFF.",".=======....I....N...N.N.F.......","............I....N....NN.F.......",".........IIIIIII.N.....N.F.......",".................................",
};char ans[20][1000];
int tot;void add(ll x, int d){stack<int> q;if (x == 0) q.push(0);while (x) {q.push(x % 10);x /= 10;}while (!q.empty()) {int top = q.top();for (int i = 1; i <= 10; i++) {if (d == 1)for (int j = tot, k = top * 8; j < tot + 8; j++, k++)ans[i][j] = a[i][k];elsefor (int j = tot, k = top * 6; j < tot + 6; j++, k++)ans[i][j] = b[i][k];}if (d == 1) tot += 8;else tot += 6;q.pop();}
}void INV(int l, int r){for (int i = 1; i <= 10; i++)for (int j = tot, tl = l; tl <= r; j++, tl++)ans[i][j] = c[i][tl];tot = tot + (r - l + 1);
}bool check(ll x, ll y){if (x == 1) return false;ll a = 1e18;for (ll i = 1; i <= y; i++) {if (a < x) return true;a /= x;}return false;
}ll qp(ll x, ll y){if (x == 1) return 1;ll t = 1;for (; y; y--) {if (t > 1e18 / x) return 1e18 + 1;t = t * x;}return t;
}
int main(){int T;cin >> T;cin.ignore();for (int t = 0; t < T; t++) {string s;getline(cin, s);ll x = 0, y = 0;size_t pos = s.find("^{");string xs = s.substr(0, pos);string ys = s.substr(pos + 2, s.size() - pos - 3);x = stoll(xs);y = stoll(ys);tot = 0;add(x, 1);add(y, 2);INV(0, 7);if (check(x, y))INV(8, 31);elseadd(qp(x, y), 1);for (int i = 1; i <= 10; i++) {ans[i][tot] = 0;printf("%s.\n", ans[i]);}printf("\n");}
}

B

发现对于ai>aj,i<j,那么i和j必须在同一个块里。否则任意即可

所以可以直接划分成最小的不可再分的几个区间。从l到i,i是右端点当且仅当区间最大值小于等于后面的最小值。把这些右端点标记一下,满足答案的必须满足是倍数

预处理一下后缀,再暴力扫一遍倍数即可

// Code Start Here	int n;cin >> n;vector<int> a(n+10) , m(n+10) , f(n+10);for(int i = 1;i<=n;i++)cin >> a[i];m[n+1] = a[n];for(int i = n;i>=1;i--)m[i] = min(m[i+1],a[i]);int max_val = 0;for(int i = 1;i<=n;i++){max_val = max(max_val , a[i]);if(max_val <= m[i + 1] || i == n){f[i] = 1;max_val = 0;}}int ans = 0;for(int i = 1;i<=n;i++){ans ++;for(int j = i;j<=n;j+=i){if(f[j] == 0){ans--;break;}}}cout << ans <<endl;

K

题意:构造一个序列使得相邻两个数差的绝对值为质数

对于n < 10可以暴力枚举,对于n > 10

若n为奇数,可以1 3 5 ... n-2 .. n .. n-3 .. n-5 .. 6 4 2

若n为偶数,可以1 3 5 .. n-3  n n-2 ...6 4 2

// Code Start Here	
int n;cin >> n;
switch (n) {
case 1: case 2: case 3: case 4:cout << "-1";break;
case 5:cout << "5 3 1 4 2";break;
case 6:cout << "5 3 1 6 4 2";break;
case 7:cout << "6 3 5 2 7 4 1";break;
case 8:cout << "6 3 8 5 2 7 4 1";break;
case 9:cout << "1 3 8 5 7 2 9 6 4";break;
default:if (n % 2) {for (int i = 4; i <= n; i += 2) {cout << i << ' ';if (n - 7 == i) cout << n - 2 << ' ';if (n - 5 == i) cout << n << ' ';}for (int i = n - 4; i >= 1; i -= 2) {cout << i << ' ';if (i == 7) cout << "2 ";}} else {for (int i = 4; i <= n; i += 2) {cout << i << ' ';if (n - 6 == i) cout << n - 1 << ' ';}for (int i = n - 3; i >= 1; i -= 2) {cout << i << ' ';if (i == 7) cout << "2 ";}}
}

E

考虑到可以使用KMP算法来计算最大前后缀,我们跑一遍KMP然后对ne数组去一个最大值即可,当最大值大于 50就可以考虑是错的

// Code Start Here	string s;cin >> s;vector<int> ne(sz(s)+10 , 0);for(int i = 1;i<sz(s);i++){int j = ne[i - 1];while(j && s[i] != s[j]){j = ne[j - 1];}if(s[j] == s[i])j++;ne[i] = j;if(ne[i] >= 50){cout <<"No" << endl;return 0;}}cout <<"Yes" <<endl;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/81694.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何用Python批量解压ZIP文件?快速解决方案

如何用Python批量解压ZIP文件&#xff1f;快速解决方案 文章目录 **如何用Python批量解压ZIP文件&#xff1f;快速解决方案**代码结果详细解释 话不多说&#xff0c;先上干货&#xff01;&#xff01;&#xff01; 代码 import os import zipfiledef unzip_file(dir_path: str…

Spring Boot 的高级特性与经典的设计模式应用

目录 1. 设计模式在 Spring Boot 中的应用 1.1 单例模式&#xff1a;Bean 管理与全局实例 1.1.1 Spring 中的单例 Bean 1.1.2 自定义单例实现 1.1.3 单例模式的优势 1.2 工厂模式&#xff1a;动态创建 Bean 1.2.1 Spring 的工厂方法 1.2.2 自定义工厂类 1.2.3 工厂模式…

在Excel中使用函数公式时,常见错误对应不同的典型问题

在Excel中使用函数公式时&#xff0c;常见错误对应不同的典型问题 1. #DIV/0!&#xff08;除以零错误&#xff09;2. #N/A&#xff08;值不可用&#xff09;3. #NAME?&#xff08;名称错误&#xff09;4. #NULL!&#xff08;空交集错误&#xff09;5. #NUM!&#xff08;数值错…

【cursor疑惑】cursor续杯后使用agent对话时,提示“需要pro或商业订阅的用户才能使用“

背景 cursor的pro会员体验过期了&#xff0c;想再次体验deepseek、Claude等agent对话提示:“免费版本不可以使用agent对话功能(英文忘记截图了&#xff0c;大意是这样)”。 处理方法 Step-1&#xff1a;再次续杯cursor的pro会员14天体验 详情&#xff0c;见&#xff1a;【c…

解决qt.network.ssl: QSslSocket::connectToHostEncrypted: TLS initialization failed

可以参考&#xff1a;解决qt.network.ssl: QSslSocket::connectToHostEncrypted: TLS initialization failed-CSDN博客 讲的是程序执行目录下可能缺少了&#xff1a; libssl-1_1-x64.dll 和 libcrypto-1_1-x64.dll 库文件&#xff0c;将其复制到可执行文件exe的同级目录下即可…

白杨SEO:不到7天,白杨SEO博客网站百度搜索显示和排名恢复正常!顺带说说上海线下GEO聚会分享和播客红利

大家好&#xff0c;我是白杨SEO&#xff0c;专注SEO十年以上&#xff0c;全网SEO流量实战派&#xff0c;AI搜索优化研究者。 5月开始&#xff0c;明显就忙起来了&#xff0c;不管是个人陪跑还是企业顾问&#xff0c;不管是需要传统SEO还是新媒体流量&#xff0c;还是当下这个A…

FART 自动化脱壳框架简介与脱壳点的选择

版权归作者所有&#xff0c;如有转发&#xff0c;请注明文章出处&#xff1a;https://cyrus-studio.github.io/blog/ FART简介 ART 环境下基于主动调用的自动化脱壳方案&#xff0c;可以解决函数抽取壳。 关于函数抽取壳的实现原理可以参考&#xff1a;基于 art 下的类加载机…

卷积神经网络进阶:转置卷积与棋盘效应详解

【内容摘要】 本文深入解析卷积神经网络中的转置卷积&#xff08;反卷积&#xff09;技术&#xff0c;重点阐述标准卷积与转置卷积的计算过程、转置卷积的上采样作用&#xff0c;以及其常见问题——棋盘效应的产生原因与解决方法&#xff0c;为图像分割、超分辨率等任务提供理论…

Redis进阶知识

Redis 1.事务2. 主从复制2.1 如何启动多个Redis服务器2.2 监控主从节点的状态2.3 断开主从复制关系2.4 额外注意2.5拓扑结构2.6 复制过程2.6.1 数据同步 3.哨兵选举原理注意事项 4.集群4.1 数据分片算法4.2 故障检测 5. 缓存5.1 缓存问题 6. 分布式锁 1.事务 Redis的事务只能保…

SDC命令详解:使用get_libs命令进行查询

相关阅读 SDC命令详解https://blog.csdn.net/weixin_45791458/category_12931432.html?spm1001.2014.3001.5482 get_libs命令用于创建一个库对象集合&#xff0c;关于设计对象和集合的更详细介绍&#xff0c;可以参考下面的博客。需要注意的是&#xff0c;在有些工具中还存在…

idea2024 不知道安装了什么插件,界面都是中文的了,不习惯,怎么修改各个选项改回英文

如果你的 IntelliJ IDEA 2024 突然变成中文界面&#xff0c;很可能是安装了中文语言包插件&#xff08;如 “Chinese (Simplified) Language Pack”&#xff09;。以下是 彻底恢复英文界面 的方法&#xff1a; 方法 1&#xff1a;直接卸载中文插件&#xff08;推荐&#xff09;…

物流项目第二期(用户端登录与双token三验证)

第一期内容&#xff1a; 物流项目第一期&#xff08;登录业务&#xff09;-CSDN博客 用户端登录 实现分析 登录功能 Data public class UserLoginRequestVO {ApiModelProperty("登录临时凭证")private String code;ApiModelProperty("手机号临时凭证"…

精准掌控张力动态,重构卷对卷工艺设计

一、MapleSim Web Handling Library仿真和虚拟调试解决方案 在柔性材料加工领域&#xff0c;卷对卷&#xff08;Roll-to-Roll&#xff09;工艺的效率与质量直接决定了产品竞争力。如何在高动态生产场景中实现张力稳定、减少断裂风险、优化加工速度&#xff0c;是行业长期面临的…

Voxblox算法

文章目录 1. 算法简介2. 由 TSDF 构建 ESDF 的方法2.1. 论文解读2.2. 伪代码实现 1. 算法简介 Voxblox 算法出现于文献《Voxblox: Incremental 3D Euclidean Signed Distance Fields for On-Board MAV Planning》&#xff0c;PDF 链接&#xff1a;https://arxiv.org/pdf/1611.…

计算机图形学基础--Games101笔记(一)数学基础与光栅化

文章目录 数学基础向量插值三角形插值双线性插值 平面定义法线-点表示 第一部分&#xff1a;光栅化坐标变换二维变换3D变换视图变换&#xff08;MVP&#xff09;投影变换 光栅化采样抗锯齿&#xff08;反走样&#xff09;可见性&#xff08;遮挡&#xff09; 着色与纹理Blinn-P…

@RequestParam 和 @RequestBody、HttpServletrequest 与HttpServletResponse

在Java Web开发中&#xff0c;RequestParam、RequestBody、HttpServletRequest 和 HttpServletResponse 是常用的组件&#xff0c;它们用于处理HTTP请求和响应。下面分别介绍它们的使用场景和使用方法&#xff1a; 1. RequestParam RequestParam 是Spring MVC框架中的注解&am…

【硬核数学】2. AI如何“学习”?微积分揭秘模型优化的奥秘《从零构建机器学习、深度学习到LLM的数学认知》

在上一篇中&#xff0c;我们探索了线性代数如何帮助AI表示数据&#xff08;向量、矩阵&#xff09;和变换数据&#xff08;矩阵乘法&#xff09;。但AI的魅力远不止于此&#xff0c;它最核心的能力是“学习”——从数据中自动调整自身&#xff0c;以做出越来越准确的预测或决策…

10.15 LangChain v0.3重磅升级:Tool Calling技术颠覆大模型工具调用,效率飙升300%!

LangChain v0.3 技术生态与未来发展:支持 Tool Calling 的大模型 关键词:LangChain Tool Calling, 大模型工具调用, @tool 装饰器, ToolMessage 管理, Few-shot Prompting 1. Tool Calling 的技术革新 LangChain v0.3 的工具调用(Tool Calling)功能标志着大模型应用开发进…

[架构之美]从PDMan一键生成数据库设计文档:Word导出全流程详解(二十)

[架构之美]从PDMan一键生成数据库设计文档&#xff1a;Word导出全流程详解&#xff08;二十&#xff09; 一、痛点 你是否经历过这些场景&#xff1f; 数据库字段频繁变更&#xff0c;维护文档耗时费力用Excel维护表结构&#xff0c;版本混乱难以追溯手动编写Word文档&#…

Image and depth from a conventional camera with a coded aperture论文阅读

Image and depth from a conventional camera with a coded aperture 1. 研究目标与实际意义1.1 研究目标1.2 实际问题与产业意义2. 创新方法:编码光圈设计与统计模型2.1 核心思路2.2 关键公式与模型架构2.2.1 图像形成模型2.2.2 深度可区分性准则2.2.3 统计模型与优化框架2.2…