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

题解:AcWing 788 逆序对的数量

【题目来源】

AcWing:788. 逆序对的数量 - AcWing题库

【题目描述】

给定一个长度为 \(n\) 的整数数列,请你计算数列中的逆序对的数量。

逆序对的定义如下:对于数列的第 \(i\) 个和第 \(j\) 个元素,如果满足 \(i<j\)\(a[i]>a[j]\),则其为一个逆序对;否则不是。

【输入】

第一行包含整数 \(n\),表示数列的长度。

第二行包含 \(n\) 个整数,表示整个数列。

【输出】

输出一个整数,表示逆序对的个数。

【输入样例】

6
2 3 4 5 6 1

【输出样例】

5

【解题思路】

image

【算法标签】

《AcWing 788 逆序对的数量》 #归并排序#

【代码详解】

#include <bits/stdc++.h>
using namespace std;typedef long long LL;  // 定义长整型别名,用于存储大数
const int N = 100010;  // 定义数组最大容量int n;      // 数组元素个数
int q[N];   // 存储待排序的数组
int tmp[N]; // 归并排序使用的临时数组// 归并排序函数,同时计算逆序对数量
LL merge_sort(int l, int r) {// 递归终止条件:区间长度小于1时不需要排序,逆序对数量为0if (l >= r) return 0;// 计算中点int mid = (l + r) >> 1;  // 等价于(l + r)/2// 递归处理左右两半,并累加逆序对数量LL res = merge_sort(l, mid) + merge_sort(mid + 1, r);// 归并过程int k = 0;        // 临时数组指针int i = l;        // 左半部分指针int j = mid + 1;  // 右半部分指针while (i <= mid && j <= r) {if (q[i] <= q[j]) {tmp[k++] = q[i++];  // 左半元素较小,直接放入} else {tmp[k++] = q[j++];  // 右半元素较小,产生逆序对res += mid - i + 1; // 统计逆序对数量}}// 处理剩余元素while (i <= mid) tmp[k++] = q[i++];  // 左半剩余元素while (j <= r) tmp[k++] = q[j++];    // 右半剩余元素// 将临时数组内容复制回原数组for (int i = l, j = 0; i <= r; i++, j++) {q[i] = tmp[j];}return res;  // 返回当前区间的逆序对总数
}int main() {// 输入数据cin >> n;for (int i = 0; i < n; i++) cin >> q[i];// 调用归并排序并输出逆序对总数cout << merge_sort(0, n - 1) << endl;return 0;
}

【运行结果】

6
2 3 4 5 6 1
5
http://www.jsqmd.com/news/397309/

相关文章:

  • 题解:AcWing 787 归并排序
  • 第1.4节 最优化理论基础 习题练习
  • 题解:AcWing 786 第k个数
  • CSS 网页布局
  • Servlet 数据库访问
  • YOLO26改进26:全网首发--C3k2融合自研创新模块C3k2_GhostDynamicConv
  • YOLO26改进27:全网首发--C3k2融合自研改进模块RVB_EMA
  • jEasyUI 创建页脚摘要
  • MySQL 删除数据表
  • centos7 中 安装docker与使用
  • Ruby Socket 编程
  • Spring IOC容器:Bean生命周期与循环依赖解决
  • 2/20
  • 2026排阻行业佼佼者,这些厂商表现亮眼,低温漂高精密电阻/抗浪涌电阻/荣誉代理/排阻,排阻公司哪家强 - 品牌推荐师
  • Python use schedule as recycle timer
  • 被小黄狗唤醒的碎碎念
  • 提示工程架构师看过来!AI提示工程质量保证的10大关键维度
  • 大数据领域ClickHouse的权限管理与审计
  • 解析AI原生应用领域思维框架的独特魅力
  • HBase与Presto集成:交互式查询解决方案
  • 芒格的“数学期望“思维:提高投资决策的准确性
  • 深度探索ing!提示工程架构师在虚拟助手中的应用奥秘大公开
  • GitHub 热榜项目 - 日榜(2026-02-20)
  • Python-flask框架的网约车个人出行顺风车在线打车租车系统出租管理平台-Pycharm django
  • IDEA创建多级包时显示在同一行怎么办
  • Python-flask框架餐饮连锁店点餐食材采购管理系统的设计与实现-Pycharm django
  • 《牛津谋杀案》电影解析
  • Python-flask框架的留守儿童心理辅导网站的设计与实现-Pycharm django
  • 大数据领域开放数据的应用场景拓展
  • Python-flask框架的积分制零食自选超市商城销售平台的设计与实现-Pycharm django