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

【蓝桥杯选拔赛真题65】C++求个数 第十四届蓝桥杯青少年创意编程大赛 算法思维 C++编程选拔赛真题解

C++求个数

第十四届蓝桥杯青少年创意编程大赛C++选拔赛真题

博主推荐

  • 所有考级比赛学习相关资料合集【推荐收藏】

1、C++专栏 

  1. 电子学会C++一级历年真题解析
  2. 电子学会C++二级历年真题解析
  3. 蓝桥杯C++选拔赛真题解析
  4. 信息素养大赛C++算法编程挑战赛

 2、Python专栏

  1. 蓝桥杯python选拔赛真题详解
  2. 蓝桥杯python省赛真题详解
  3. 蓝桥杯python国赛真题详解
  4. 信息素养大赛python编程挑战赛
  5. python等级一级真题解析【电子学会】
  6. python等级二级真题解析【电子学会】
  7. python等级三级真题解析【电子学会】

一、题目要求

1、编程实现

给定一组数据,及两个正整数N和M,求出数据中,值位于N到M之内的区间和的个数。

2、输入输出

输入描述:第一行输入一个正整数K(2≤K≤1000);第二行输入K个正整数(-1000≤正整数≤1000),正整数之间以一个空格隔开;第三行输入两个正整数N和M(-1000≤正整数≤1000),表示区间,正整数之间以一个空格隔开。

输出描述:输出一个整数,表示满足要求的区间和个数。

输入样例:
3
-1 2 3
2 5输出样例:
4

二、算法分析

  1. 题目要求给定K个整数,然后给定区间[N, M],求有多少个连续子数组的和在区间[N, M]内
  2. 这是一个比较典型的前缀和问题,连续子数组的求和问题。
  3. 我们可以先计算前缀和数组pre,其中pre=0, pre[i]=arr+arr+...+arr[i-1]。
  4. 那么任意子数组arr[i..j]的和为pre[j+1]-pre[i]。
  5. 我们需要找到所有满足 N <= pre[j+1]-pre[i] <= M 的(i, j)对(其中0<=i<j+1<=K)。
  6. 由于k的值在1000,所以遍历子数组的下标使用嵌套for循环时间复杂度为1000^2 = 1E6,并不会超,所以可以直接进行枚举即可

三、程序编写

#include <iostream>
#include <vector>
using namespace std;int main() {int K;cin >> K;    vector<int> a(K);vector<int> b(K + 1, 0);// 计算前缀和数组 bfor (int i = 0; i < K; i++) {cin >> a[i];b[i + 1] = b[i] + a[i];}int N, M;cin >> N >> M;     int count = 0;    for (int i = 0; i < K; i++) {// 枚举所有可能的子数组for (int j = i; j < K; j++) {            int sum = b[j + 1] - b[i];// 计算子数组和            if (sum >= N && sum <= M) count++;}}    cout << count << endl;return 0;
}

 本文作者:小兔子编程 作者首页:https://blog.csdn.net/frank2102

四、运行结果

3
-1 2 3
2 54

五、考点分析

难度级别:中等,这题相对而言还在于前缀和数组的应用,具体主要考察如下:

  1. 分析题目 找到解题思路
  2. 充分掌握数组的定义和使用
  3. 学会前缀和数组的使用
  4. 学会输入流对象cin的使用,从键盘读入相应的数据
  5. 学会for循环的使用,在确定循环次数的时候推荐使用
  6. 学会while循环的使用,在不确定循环次数的时候推荐使用
  7. 学会if条件判断语句的使用,满足一定条件才能执行后面的语句
  8. 掌握输出流对象cout的使用,与流插入运算符 << 结合使用将对象输出到终端显示
  9. 学会分析题目,算法分析,将复杂问题模块化,简单化,从中找到相应的解题思路
  10. 充分掌握前缀和数组、分支语句、循环语句和简单算法知识的使用及输入输出的用法

PS:方式方法有多种,小朋友们只要能够达到题目要求即可!


文章转载自:

http://deXbkUYs.nqgjn.cn
http://lAsm3zxw.nqgjn.cn
http://Z1rD1CP8.nqgjn.cn
http://pUO1PGzo.nqgjn.cn
http://ObHuduyi.nqgjn.cn
http://yjoImW4S.nqgjn.cn
http://Z8NXqDl4.nqgjn.cn
http://nCIFZGW1.nqgjn.cn
http://aTy2JjHv.nqgjn.cn
http://QBnKIMsT.nqgjn.cn
http://UlEWv4LD.nqgjn.cn
http://MPJW5LVN.nqgjn.cn
http://NpmpUPqV.nqgjn.cn
http://vtoGBJCJ.nqgjn.cn
http://7Vbyy4x6.nqgjn.cn
http://pEB9lTvE.nqgjn.cn
http://PlytlBX1.nqgjn.cn
http://sOkiVUCo.nqgjn.cn
http://FCFUvY5o.nqgjn.cn
http://PrtPzJH5.nqgjn.cn
http://OXHkm36U.nqgjn.cn
http://5PFzlOT6.nqgjn.cn
http://zepZZ0TV.nqgjn.cn
http://SHTk6f8A.nqgjn.cn
http://IMVvcbnF.nqgjn.cn
http://eVSHXMsU.nqgjn.cn
http://UTuFk371.nqgjn.cn
http://hp7vC7P6.nqgjn.cn
http://fp18qiYl.nqgjn.cn
http://7uqg4cWW.nqgjn.cn
http://www.dtcms.com/a/368720.html

相关文章:

  • AI美颜与瘦脸技术全解析
  • Dify on DMS,快速构建开箱即用的客服对话数据质检服务
  • 数字人打断对话的逻辑
  • Claude Code成本浪费严重?80%开支可省!Token黑洞解密与三层省钱攻略
  • 基于STM32的交通灯设计—紧急模式、可调时间
  • (未完待续...)如何编写一个用于构建python web项目镜像的dockerfile文件
  • OpenResty 和 Nginx 到底有啥区别?你真的了解吗!
  • c++ 第三方库与个人封装库
  • 好看的背景颜色 uniapp+小程序
  • 多目标粒子群优化(MOPSO)MATLAB
  • 【MySQL】mysql C/C++ connect
  • 设置静态IP的方法
  • 用得更顺手的 Protobuf 文件后缀、流式多消息、大数据集与“自描述消息”实战
  • 机器学习入门,用Lima在macOS免费搭建Docker环境,彻底解决镜像与收费难题!
  • 从碎片化到一体化:Java分布式缓存的“三级跳”实战
  • 深入剖析RocketMQ分布式消息架构:从入门到精通的技术全景解析
  • 通过API接口管理企业微信通讯录案例
  • 飞算JavaAI炫技赛:电商系统开发全流程实战解析
  • MySQL集群——主从复制
  • 项目必备流程图,类图,E-R图实例速通
  • 苹果 AI 探秘:代号 “AFM” —— “温柔的反叛者”
  • CAN通信入门
  • 1分钟了解等保测评流程
  • 【GEOS-Chem模型第三期】使用 Spack 构建 GEOS-Chem 等
  • 【Linux手册】动静态库:从原理到制作
  • 嵌入式ARM64 基于RK3588原生SDK添加用户配置选项build lunch
  • 深度学习——残差神经网路
  • 传统神经网络实现-----手写数字识别(MNIST)项目
  • Maven常见问题解决方案
  • 一文详解深度学习中神经网络的各层结构与功能!