题目描述

给一个双向冒泡排序的程序:

moo表示输出moo

sorted = false
while (not sorted):
sorted = true
moo
for i = to N-:
if A[i+] < A[i]:
swap A[i], A[i+]
for i = N- downto :
if A[i+] < A[i]:
swap A[i], A[i+]
for i = to N-:
if A[i+] < A[i]:
sorted = false

再给一个初始的数组。

求把这个数组排好序,输出几次moo

n<=100000,ai<=1e9

题解

考察冒泡排序的本质。

一般的冒泡排序,每次会把最大的数直接沉底,

但是比较小的数,会往前面缓慢冒泡。

具体来说,如果一个数i排名是i,但是位置在i之后,那么,每次循环,i必然会往前面移动一位。

因为必然前面会有一个比i大的数往后沉。

i往前每次移动一次导致复杂度最坏是n^2

swap的次数,就是逆序对数

循环的次数,就是

这个题目,是一个双向的冒泡排序,

对于一个分界点位置i,这个双向排序,每个循环会把一个i之前的大于i的数移到i后面,并且把一个i后面小于i的数移到i的前面。

单向冒泡不能保证每次把一个i后面的小于i的数放到i前面。

排好序是什么意思?

就是说,对于任意的位置i,小于i的数都在i前面,大于i的数都在i后面。

所以 ,我们可以对于所有的位置i,找到i前面比i小的数个数s,i-s就是i位置把小于i的放在i前面,大于i的放在i后面的循环次数。

例如 5 2 3 1 4 双向冒泡可以一次排完。单向冒泡瓶颈在“3”

对于这些次数取一个mx即可。

用树状数组离散化后可以做。

代码:

#include<bits/stdc++.h>
using namespace std;
const int N=+;
int n,ans;
int a[N],b[N],cnt[N];
int f[N];
void add(int x){for(;x<=n;x+=x&(-x)) f[x]++;}
int query(int x){int ret=;for(;x;x-=x&(-x))ret+=f[x];return ret;}
int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++){
scanf("%d",&a[i]);b[i]=a[i];
}
sort(b+,b+n+);ans=;
for(int i=;i<=n;i++){
int t=lower_bound(b+,b+n+,a[i])-b;
//cout<<" tt "<<t<<endl;
add(t);
cnt[i]=query(i);ans=max(ans,i-cnt[i]);
}printf("%d",ans);return ;
}

注意,当数组排好序之后,因为一定要检查一遍,所以moo还是1的。不是0

upda:2019.9.20

这个是通过位置来处理最大值的

还可以通过数值,每个数值每次会有一个在前面且比它大的数放到后面去,而每次会有一个在后面比它小的数到前面去。

同理离散化+树状数组,for i=1~n      ans =max(ans,max(number of front and big,number of back and small))

[USACO18OPEN]Out of Sorts G 冒泡排序理解之一的更多相关文章

  1. [USACO18OPEN]Out of Sorts P 冒泡排序理解之二

    题目描述 Bessie把快速排序和冒泡排序混在了一起 给一个伪快排的代码: 冒泡: bubble_sort_pass (A) { to length(A)- ], swap A[i] and A[i+ ...

  2. 洛谷 P4375 [USACO18OPEN]Out of Sorts G(树状数组求冒泡排序循环次数加强版)

    传送门:Problem 4375 参考资料: [1]:https://www.cnblogs.com/Miracevin/p/9662350.html [2]:https://blog.csdn.ne ...

  3. 洛谷 P4378 [USACO18OPEN]Out of Sorts S(树状数组求冒泡排序循环次数)

    传送门:Problem P4378 https://www.cnblogs.com/violet-acmer/p/9833502.html 要回宿舍休息了,题解明天再补吧. 题解: 定义一数组 a[m ...

  4. bzoj 5277: [Usaco2018 Open]Out of Sorts【冒泡排序瞎搞】

    首先考虑快排的递归什么时候停下,显然是当前段只剩下一个数了,也就是一个数两边出现分隔符 然后再考虑计算冒泡长度这个操作,因为有分割,所以我们可以把这些放到一起冒泡,这和递归每个区间冒泡是等价的 所以答 ...

  5. Java基础进阶:APi使用,Math,Arrarys,Objects工具类,自动拆装箱,字符串与基本数据类型互转,递归算法源码,冒泡排序源码实现,快排实现源码,附重难点,代码实现源码,课堂笔记,课后扩展及答案

    要点摘要 Math: 类中么有构造方法,内部方法是静态的,可以直接类名.方式调用 常用: Math.abs(int a):返回参数绝对值 Math.ceil(double a):返回大于或等于参数的最 ...

  6. SED总结, mac上要加备份文件名,sort命令和对中文的处理

    使用sed批量改文件名 Sed批量去拓展名 |- dev.gb.conll06.raw |- test.gb.conll06.raw |- train.gb.conll06.raw 想要去掉其中的后缀 ...

  7. 软件工程导论-目录-K-T+RJ大

    目录 10 第1章 软件工程学概述/1 19 1.1 软件危机/1 19 1.1.1 软件危机的介绍/1 19 1.1.2 产生软件危机的原因/3 21 1.1.3 消除软件危机的途径/4 22 1. ...

  8. C语言学习笔记---谭浩强

    前段时间有机会去面试了一次,真是备受“打击”(其实是启发),总的来说就是让我意识到了学习工具和学习技术的区别.所以最近在看一些数据结构和算法,操作系统,python中的并行编程与异步编程等东西.然而数 ...

  9. 前端技术-svg简介与snap.svg.js开源项目的使用

    前言-为什么学习snap.svg.js 前阵子webAPP的技术群里有人感觉到svg+animate的形式感觉很炫,矢量图任意放大且不需要下载图片,并且在手机端效果流畅. (矢量图与位图最大的区别是, ...

随机推荐

  1. HTML基础之DOM操作

    DOM(Document Object Model 文档对象模型) 一个web页面的展示,是由html标签组合成的一个页面,dom对象实际就是将html标签转换成了一个文档对象.可以通过dom对象中j ...

  2. idea 迁移maven项目出现导入仓库半天没反应的问题解决

    可以先参考: https://www.cnblogs.com/kinome/p/10289212.html 然后再看看maven配置文件是否正确,项目进行迁移时,如果环境不同,比如一个是使用的自定义m ...

  3. Flutter - 创建侧滑菜单(不使用navigatior,仅改变content)

    之前写过一篇文章,Flutter - 创建横跨所有页面的侧滑菜单.这个里面中使用了Navigator.of(context).push来导航到新的页面. 这次介绍一种不使用导航,仅仅改变content ...

  4. LeetCode Generate Parentheses (DFS)

    题意 Given n pairs of parentheses, write a function to generate all combinations of well-formed parent ...

  5. 基于Vue手写一个下拉刷新

    当然不乏有很多下拉刷新的插件可以直接使用,但是自定义程度不强,大部分都只能改改文字,很难满足设计师的创意,譬如淘宝和京东首页那种效果,就需要自己花心思倒腾了,最近刚好有这种需求,做完了稍微总结一下,具 ...

  6. 记录:Ubuntu 18.04 安装 tensorflow-gpu 版本

    狠下心来重新装了系统,探索一下 gpu 版本的安装.比较令人可喜的是,跟着前辈们的经验,还是让我给安装成功了.由于我是新装的系统,就像婴儿般纯净,所以进入系统的第一步就是安装 cuda,只要这个不出错 ...

  7. 如何干净的卸载docker

    先上服务器环境信息: 卸载的原因: 宿主机过段时间就磁盘100%了,导致continart异常退出,后来找了很多解决方案,才发现是安装docker的时候有个配置文件错误(正常的应该是|Storage ...

  8. SCRUM 12.15

    今天我们所有的团队成员都加速的进行着开发.虽然最近3门大作业压着,我们还是抽出了足够多的时间对项目的M2阶段进行完善. 今天我们完成了清除缓存的功能,另外我们的单页爬虫也已经设计完成,我们的进度在我们 ...

  9. Linux第一周学习总结——计算机是如何工作的

    第一周学习总结--计算机是如何工作的 作者:刘浩晨 一.存储程序计算机工作模型 冯诺依曼体系结构:核心思想为存储程序计算机.两个层面: (1)硬件的角度(计算机主板):一个CPU,一块内存,之间有总线 ...

  10. 使用Visual Studio 2013进行单元测试的过程与感想

    首先是安装Visual Studio 2013这个软件,尽管安装过程不复杂,但是安装的时间实在是太长了,经过2个多小时的安装终于装完了. 由于时间紧凑,没来得及装语言包,于是,我用了原装的进行了单元测 ...