博客
关于我
归并排序 · 求逆序对
阅读量:250 次
发布时间:2019-03-01

本文共 784 字,大约阅读时间需要 2 分钟。

#include 
using namespace std;typedef long long ll;const int N = 1e6 + 10;int n, res, K;int a[N], b[N];void merge(int l, int r) { if (l >= r) return; int mid = l + r >> 1; merge(l, mid); merge(mid + 1, r); int i = l, j = mid + 1, k = l; while (i <= mid && j <= r) { if (a[i] <= a[j]) { b[k++] = a[i++]; } else { b[k++] = a[j++]; res += mid - i + 1;//统计答案 } while (i <= mid)b[k++] = a[i++]; while (j <= r)b[k++] = a[j++]; for (int i = l; i <= r; i++) { a[i] = b[i]; } }}int main() { ios::sync_with_stdio(0); cin >> n; for (int i = 1; i <= n; ++i) { cin >> a[i]; } merge(1, n); cout << res << endl; return 0;}

转载地址:http://cjet.baihongyu.com/

你可能感兴趣的文章
MySQL索引底层:B+树详解
查看>>
Mysql索引总结
查看>>
MySQL索引背后的数据结构及算法原理
查看>>
mysql经常使用命令
查看>>
mysql给账号授权相关功能 | 表、视图等
查看>>
MySQL缓存使用率超过80%的解决方法
查看>>
Mysql缓存调优的基本知识(附Demo)
查看>>
mysql网站打开慢问题排查&数据库优化
查看>>
mysql网络部分代码
查看>>
mysql自动化同步校验_Shell: 分享MySQL数据同步+主从复制自动化脚本_20190313_七侠镇莫尛貝...
查看>>
mysql自增id超大问题查询
查看>>
MySQL自带information_schema数据库使用
查看>>
MySQL获取分组后的TOP 1和TOP N记录
查看>>
MySQL蜜罐反制获取攻击者信息
查看>>
Mysql表创建外键报错
查看>>
mysql表格调取数据库信息_MySQL™ 参考手册(获取有关数据库和表的信息)
查看>>
MySQL视图
查看>>
mysql视图建立MERGE算法和TEMPTABLE算法的区别(效率与表锁定问题)
查看>>
MySQL设置白名单限制
查看>>
MySQL设置远程连接
查看>>