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

【题解-洛谷】P9422 [蓝桥杯 2023 国 B] 合并数列

题目:P9422 [蓝桥杯 2023 国 B] 合并数列

题目描述

小明发现有很多方案可以把一个很大的正整数拆成若干正整数的和。他采取了其中两种方案,分别将他们列为两个数组 { a 1 , a 2 , ⋯ a n } \{a_1, a_2, \cdots a_n\} {a1,a2,an} { b 1 , b 2 , ⋯ b m } \{b_1, b_2, \cdots b_m\} {b1,b2,bm}。两个数组的和相同。

定义一次合并操作可以将某数组内相邻的两个数合并为一个新数,新数的值是原来两个数的和。小明想通过若干次合并操作将两个数组变成一模一样,即 n = m n = m n=m 且对于任意下标 i i i 满足 a i = b i a_i = b_i ai=bi。请计算至少需要多少次合并操作可以完成小明的目标。

输入格式

输入共 3 3 3 行。

第一行为两个正整数 n , m n, m n,m

第二行为 n n n 个由空格隔开的整数 a 1 , a 2 , ⋯ , a n a_1, a_2, \cdots, a_n a1,a2,,an

第三行为 m m m 个由空格隔开的整数 b 1 , b 2 , ⋯ , b m b_1, b_2, \cdots, b_m b1,b2,,bm

输出格式

输出共 1 1 1 行,一个整数。

输入输出样例 #1

输入 #1

4 3
1 2 3 4
1 5 4

输出 #1

1

说明/提示

样例说明

只需要将 a 2 a_2 a2 a 3 a_3 a3 合并,数组 a a a 变为 { 1 , 5 , 4 } \{1,5,4\} {1,5,4},即和 b b b 相同。

评测用例规模与约定

  • 对于 20 % 20\% 20% 的数据,保证 n , m ≤ 10 3 n,m \le 10^3 n,m103
  • 对于 100 % 100\% 100% 的数据,保证 n , m ≤ 10 5 n, m \le 10^5 n,m105 0 < a i , b i ≤ 10 5 0 < a_i, b_i \le 10^5 0<ai,bi105

第十四届蓝桥杯大赛软件赛决赛 C/C++ 大学 B 组 D 题

代码

#include<iostream>using namespace std;typedef long long LL;const int Maxn = 1e5 + 10;LL n, m, a[Maxn], b[Maxn], q1[Maxn], q2[Maxn], hh1, tt1 = -1, hh2, tt2 = -1, sum;void insert(int id, LL x){if(id == 1){q1[++ tt1] = x;}else{q2[++ tt2] = x;}
}void dele(int id){if(id == 1){hh1 ++;}else{hh2 ++;}
}bool isempty(int id){if(id == 1){return hh1 > tt1;}else{return hh2 > tt2;}
}int main(){cin >> n >> m;for(int i = 0; i < n; i ++){int x;cin >> x;insert(1, x);}for(int i = 0; i < m; i ++){int x;cin >> x;insert(2, x);}while(!isempty(1) || !isempty(2)){LL a = q1[hh1];dele(1);LL b = q2[hh2];dele(2);while(a < b){a += q1[hh1];dele(1);sum ++;}while(b > a){b += q2[hh2];dele(2);sum ++;}}cout << sum;return 0;
}

结果

在这里插入图片描述
在这里插入图片描述

http://www.lryc.cn/news/2399332.html

相关文章:

  • 在MATLAB中,`mean(P_train, 2)` 的含义
  • 开源模型应用落地-OpenAI Agents SDK-集成Qwen3-8B(一)
  • 109页PPT华为流程模块L1-L4级梳理及研发采购服务资产5级建模
  • 第N1周:one-hot编码案例
  • Windows安装docker desktop
  • Ros(俩不同包的节点 交流 topic message)
  • 李沐《动手学深度学习》 | 数值稳定性
  • OpenCV CUDA模块图像处理------图像连通域标记接口函数connectedComponents()
  • Android Studio 打包时遇到了签名报错问题:Invalid keystore format
  • 内存管理【Linux操作系统】
  • Go语言学习-->从零开始搭建环境
  • 【力扣】3403. 从盒子中找出字典序最大的字符串 I
  • 苹果企业签名撤销
  • 12306高并发计算架构揭秘:Apache Geode 客户端接入与实践
  • JSON to Excel 3.0.0 版本发布 - 从Excel插件到Web应用的转变
  • 【前端】Vue3+elementui+ts,给标签设置样式属性style时,提示type check failed for prop,再次请出DeepSeek来解答
  • Neo4j 监控全解析:原理、技术、技巧与最佳实践
  • PyTorch——优化器(9)
  • 07 APP 自动化- appium+pytest+allure框架封装
  • Postgresql常规SQL语句操作
  • 智能合约安全漏洞解析:从 Reentrancy 到 Integer Overflow
  • 英国2025年战略防御评估报告:网络与电磁域成现代战争核心
  • 基于QPSK调制解调+Polar编译码(SCL译码)的matlab性能仿真,并对比BPSK
  • go语言学习 第5章:函数
  • Qt Quick快速入门笔记
  • 《波段操盘实战技法》速读笔记
  • Glide NoResultEncoderAvailableException异常解决
  • 工厂模式与多态结合
  • 无人机巡检智能边缘计算终端技术方案‌‌——基于EFISH-SCB-RK3588工控机/SAIL-RK3588核心板的国产化替代方案‌
  • 相机--相机成像原理和基础概念