[USACO18OPEN]Out of Sorts G 冒泡排序理解之一
题目描述
给一个双向冒泡排序的程序:
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 冒泡排序理解之一的更多相关文章
- [USACO18OPEN]Out of Sorts P 冒泡排序理解之二
题目描述 Bessie把快速排序和冒泡排序混在了一起 给一个伪快排的代码: 冒泡: bubble_sort_pass (A) { to length(A)- ], swap A[i] and A[i+ ...
- 洛谷 P4375 [USACO18OPEN]Out of Sorts G(树状数组求冒泡排序循环次数加强版)
传送门:Problem 4375 参考资料: [1]:https://www.cnblogs.com/Miracevin/p/9662350.html [2]:https://blog.csdn.ne ...
- 洛谷 P4378 [USACO18OPEN]Out of Sorts S(树状数组求冒泡排序循环次数)
传送门:Problem P4378 https://www.cnblogs.com/violet-acmer/p/9833502.html 要回宿舍休息了,题解明天再补吧. 题解: 定义一数组 a[m ...
- bzoj 5277: [Usaco2018 Open]Out of Sorts【冒泡排序瞎搞】
首先考虑快排的递归什么时候停下,显然是当前段只剩下一个数了,也就是一个数两边出现分隔符 然后再考虑计算冒泡长度这个操作,因为有分割,所以我们可以把这些放到一起冒泡,这和递归每个区间冒泡是等价的 所以答 ...
- Java基础进阶:APi使用,Math,Arrarys,Objects工具类,自动拆装箱,字符串与基本数据类型互转,递归算法源码,冒泡排序源码实现,快排实现源码,附重难点,代码实现源码,课堂笔记,课后扩展及答案
要点摘要 Math: 类中么有构造方法,内部方法是静态的,可以直接类名.方式调用 常用: Math.abs(int a):返回参数绝对值 Math.ceil(double a):返回大于或等于参数的最 ...
- SED总结, mac上要加备份文件名,sort命令和对中文的处理
使用sed批量改文件名 Sed批量去拓展名 |- dev.gb.conll06.raw |- test.gb.conll06.raw |- train.gb.conll06.raw 想要去掉其中的后缀 ...
- 软件工程导论-目录-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. ...
- C语言学习笔记---谭浩强
前段时间有机会去面试了一次,真是备受“打击”(其实是启发),总的来说就是让我意识到了学习工具和学习技术的区别.所以最近在看一些数据结构和算法,操作系统,python中的并行编程与异步编程等东西.然而数 ...
- 前端技术-svg简介与snap.svg.js开源项目的使用
前言-为什么学习snap.svg.js 前阵子webAPP的技术群里有人感觉到svg+animate的形式感觉很炫,矢量图任意放大且不需要下载图片,并且在手机端效果流畅. (矢量图与位图最大的区别是, ...
随机推荐
- Hadoop日记Day11---主从节点接口分析
一.NameNode 的接口分析 1. NameNode本质 经过前面的学习,可以知道NameNode 本身就是一个java 进程.观察RPC.getServer()方法的第一个参数,发现是this, ...
- [hdu5503]EarthCup[霍尔定理]
题意 一共 \(n\) 只球队,两两之间会进行一场比赛,赢得一分输不得分,给出每只球队最后的得分,问能否构造每场比赛的输赢情况使得得分成立.多组数据 \(T\le 10,n\le 5\times 10 ...
- 内幕:XX二手车直卖网,狗屁直卖网,我来揭开他们套路!
转自:明锐论坛 我是一位花生二手车直卖网的离职员工.已离职了一段时间,现在在某家汽车4S店公司上班.过去了那么久,每当看到他们铺天盖地的广告,心里都像十五个水桶--七上八下.思索已久,我还是决定鼓 ...
- 我是SPI,我让框架更加优雅了!
文章首发于[陈树义的博客],点击跳转到原文<我是 SPI,我让框架更加优雅了!> 自从上次小黑进入公司的架构组之后,小黑就承担起整个公司底层框架的开发工作.就在刚刚,小黑又接到一个任务:做 ...
- javascript典型bug——错误的闭包
昨天QT给我的一个功能提了一个bug.大概意思就是说,一段在不同位置都会被调用的代码,在A处被调用的时候,似乎会对其他调用的地方产生影响. 我仔细debug了半天,终于找到了原因.简化过的代码如下: ...
- OPPO A7X 刷机小结
OPPO A7X 刷机小结: 概述:根据网上找到的教程(MTK模式刷机教程),没有成功.在QQ上询问一位提供刷机服务的大神,说是只有老版本才能刷. 操作步骤: 刷机工具: MediaTek SP Fl ...
- nodejs 监控代码变动实现ftp上传
被动模式下 //https://www.npmjs.com/package/watch //文件同步功能 var watch = require('watch'); var path = requir ...
- 框架-Spring
项目中都用到了Spring.Mybatis.SpringMVC框架,首先来谈一谈Spring框架,Spring框架以IOC.AOP作为主要思想. IOC----控制反转 IOC的全称为Inversio ...
- Leetcode题库——38.报数
@author: ZZQ @software: PyCharm @file: countAndSay.py @time: 2018/11/9 14:07 说明:报数序列是一个整数序列,按照其中的整数的 ...
- 剑指offer:二叉树的深度
题目描述: 输入一棵二叉树,求该树的深度.从根结点到叶结点依次经过的结点(含根.叶结点)形成树的一条路径,最长路径的长度为树的深度. 解题思路: 这道题也是递归的思路,比较简单. 做的过程中遇到的一个 ...