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

GESP认证C++编程真题解析 | B3874 [GESP202309 六级] 小杨的握手问题

​欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!

专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。

适合人群:

  • 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
  • 希望系统学习C++/Python编程的初学者
  • 想要提升算法与编程能力的编程爱好者

附上汇总帖:GESP认证C++编程真题解析 | 汇总


【题目来源】

洛谷:[B3874 GESP202309 六级] 小杨的握手问题 - 洛谷

【题目描述】

小杨的班级里共有N NN名同学,学号从0 00N − 1 N-1N1

某节课上,老师安排全班同学进行一次握手游戏,具体规则如下:老师安排了一个顺序,让全班N NN名同学依次进入教室。每位同学进入教室时,需要和已经在教室内学号小于自己的同学握手。

现在,小杨想知道,整个班级总共会进行多少次握手。

提示:可以考虑使用归并排序进行降序排序,并在此过程中求解。

【输入】

输入包含2 22行。第一行一个整数N NN,表示同学的个数;第二行N NN个用单个空格隔开的整数,依次描述同学们进入教室的顺序,每个整数在0 ∼ N − 1 0 \sim N-10N1之间,表示该同学的学号。

保证每位同学会且只会进入教室一次。

【输出】

输出一行一个整数,表示全班握手的总次数。

【输入样例】

4 2 1 3 0

【输出样例】

2

【算法标签】

《洛谷 B3874 小杨的握手问题》 #树状数组# #递归# #排序# #GESP# #2023#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;#defineintlonglongconstintN=300005;// 树状数组大小,要大于最大可能的值intn;// 数组长度intans;// 逆序对总数inttr[N];// 树状数组/** * 计算lowbit:返回x的二进制表示中最低位的1所对应的值 * 例如:lowbit(6)=2,因为6的二进制是110,最低位的1表示2 * @param x 输入数字 * @return lowbit值 */intlowbit(intx){returnx&-x;// 利用补码性质:x & -x}/** * 树状数组更新操作 * 在位置x上增加c * @param x 更新位置 * @param c 增加的值 */voidadd(intx,intc){// 从x开始,沿lowbit路径向上更新所有包含x的区间for(inti=x;i<=N;i+=lowbit(i)){tr[i]+=c;}}/** * 树状数组查询操作 * 查询前缀和[1, x] * @param x 查询位置 * @return 前缀和 */intquery(intx){intres=0;// 从x开始,沿lowbit路径向下累加for(inti=x;i;i-=lowbit(i)){res+=tr[i];}returnres;}signedmain()// 因为使用了#define int long long{// 输入数组长度cin>>n;// 从后向前遍历数组for(inti=n;i>=1;i--){intx;cin>>x;x++;// 将数值从0-based转为1-based,避免树状数组处理0// 查询在当前位置之前(在原始顺序中)有多少个比x小的数// 因为是从后向前遍历,所以query(x)返回的是已经处理过的数中小于等于x的数量// 但我们需要的是严格小于x的数量,所以这里有问题ans+=query(x);// 将当前数加入树状数组add(x,1);}// 输出逆序对总数cout<<ans<<endl;return0;}

【运行结果】

4 2 1 3 0 2
http://www.cnnetsun.cn/news/152137.html

相关文章:

  • 2025网络信息安全工程师入行路线图:从零基础到体系精通,一篇保姆级指南
  • 算法学习记录18——并查集 vs Set + BFS/DFS
  • 揭秘Open-AutoGLM离线运行核心技术:5大关键步骤让你摆脱云端依赖
  • 29、量子点中的自旋电子学与量子计算
  • 千元到两千元家用路由器市场,如何挑选及Wi-Fi 7技术优势
  • 【Open-AutoGLM触控优化核心技术】:揭秘轨迹自然度提升的5大算法原理
  • FaceFusion助力元宇宙建设:高质量面部动画生成解决方案
  • FaceFusion命令行工具详解:自动化脚本编写实战
  • 【Open-AutoGLM性能突围】:3个真实案例教你将推理延迟压到极限
  • 从零基础转行渗透测试到如今20k,我经历了什么?_渗透测试工作辛苦吗
  • 错过Transformer时代别再错过它:Open-AutoGLM将引爆下一代AI浪潮?
  • Open-AutoGLM无代码系统背后的秘密(9大核心技术组件详解)
  • 基于Java的毕业论文复现与写作,这10款AI工具值得推荐
  • 利用FaceFusion镜像加速GPU算力变现的新商业模式
  • pytest-yaml 测试平台 - 平台实现用例分层API和用例层
  • Open-AutoGLM实战指南:5步构建你的动态强化学习智能体
  • 计算机毕业设计springboot家庭财务管理系统APP 基于Spring Boot的家庭财务智能管理移动应用开发 Spring Boot驱动的家庭财务管理系统移动端设计与实现
  • Open-AutoGLM坐标漂移难题,一文掌握精准修正的7种高级手法
  • (独家)Open-AutoGLM弹窗自愈系统设计内幕:3步实现无人值守自动处理
  • 从规则引擎到AI决策,弹窗处理如何迈入智能化时代?,Open-AutoGLM实战路径全披露
  • 无路可退的渗透测试工程师,35岁前趁早多接触下这些方向
  • 非科班学网络安全,是“黄金大道”还是“天坑之旅”?
  • C语言变量命名规则C语言变量与常量基本数据类型
  • 1、数学物理中的量化与群论研究
  • 18、物理中的几何方法与模型研究
  • 2、量子物理早期实验与理论探索
  • 基于ssm的面向企事业单位的项目申报小程序源代码(源码+文档+数据库)
  • FaceFusion镜像提供多维度性能指标看板
  • 30、6G 网络:连接未来的无限可能
  • AIDD-人工智能药物设计-AI 药物重定位:GraphRAG 让黑箱模型说人话