思路:

首先我们注意到,对一个序列按分割点分开以后分别冒泡其实就相当于对整个序列进行冒泡。每一个元素都会对复杂度贡献1,除非一个元素两边的分割点都出现了。因此我们可以完全忽略快排的递归过程。只需考虑每个元素在经历几趟冒泡排序之后两边的分割点都出现了。

考虑一个分割点,不妨就是在i,i+1之间的这个分割点,他在几趟冒泡排序之后会出现呢?出现了这个分割点,说明前i小的元素都已经在前i个了,我们记前i小的元素一开始最大的下标为x,则在x-i趟冒泡之后就会把x挪到前i个位置(因为每趟冒泡一定会使x的下标-1)。也就是说i,i+1之间的分割点会在x-i趟冒泡之后出现。而第i个元素的贡献就是它左右分割点出现时间的最大值。

from https://blog.csdn.net/Icefox_zhx/article/details/80025305

注意如果有相同的数的时候,按照出现的position从小到大排序

(这破题搞了一上午我真是退役选手了)

//By SiriusRen
#include <bits/stdc++.h>
using namespace std;
const int N=;
int n,mx[N],cnt[N];long long ans;
struct Nd{int w,p;}a[N];
bool cmp(Nd a,Nd b){if(a.w!=b.w)return a.w<b.w;return a.p<b.p;}
int main(){
scanf("%d",&n);
for(int i=;i<=n;i++)scanf("%d",&a[i].w),a[i].p=i;
sort(a+,a++n,cmp);
for(int i=;i<n;i++)mx[i]=max(mx[i-],a[i].p),cnt[i]=max(mx[i]-i,);
for(int i=;i<=n;i++)ans+=max(cnt[i],cnt[i-]);
printf("%lld\n",ans);
}

附一个暴力程序

//By SiriusRen
#include <bits/stdc++.h>
using namespace std;
const int N=,inf=0x3f3f3f3f;
int n,a[N],work_counter,minn[N],maxx[N];
void bubble_sort_pass(int *a,int len){
    for(int i=;i<=len-;i++)if(a[i]>a[i+])swap(a[i],a[i+]);
}
int get_partition_points(int *a,int len){
    minn[len]=inf;maxx[]=a[];int temp=;
    for(int i=len-;~i;i--)minn[i]=min(minn[i+],a[i]);
    for(int i=;i<len;i++)maxx[i]=max(maxx[i-],a[i]);
    for(int i=;i<len-;i++)if(maxx[i]<=minn[i+])temp++;
    return temp;
}
void quickish_sort(int *a,int len){
    if(len==)return;
    work_counter+=len,bubble_sort_pass(a,len);
    minn[len]=inf;maxx[]=a[];int temp=;
    for(int i=len-;~i;i--)minn[i]=min(minn[i+],a[i]);
    for(int i=;i<len;i++)maxx[i]=max(maxx[i-],a[i]);
    vector<int>v;
    for(int i=;i<len-;i++)if(maxx[i]<=minn[i+])v.push_back(i);
    if(v.empty())return;
    quickish_sort(a,v[]+);
    for(int i=;i<v.size()-;i++)quickish_sort(a+v[i]+,v[i+]-v[i]);
    quickish_sort(a+v[v.size()-]+,len-v[v.size()-]-);
}
int main(){
    scanf("%d",&n);
    for(int i=;i<n;i++)scanf("%d",&a[i]);
    quickish_sort(a,n);
    printf("%d\n",work_counter);
}

BZOJ 5277 IQ题orz的更多相关文章

  1. BZOJ 无数据题集合

    题目 http://www.lydsy.com/JudgeOnline/problem.php?id=1142 http://www.lydsy.com/JudgeOnline/problem.php ...

  2. bzoj 前100题计划

    bzoj前100题计划 xz布置的巨大的坑.. 有空填题解... 1002 轮状病毒 用python手动matrixtree打表. #include<bits/stdc++.h> #def ...

  3. BZOJ的思维题

    5085:最大 给你一个n×m的矩形,要你找一个子矩形,价值为左上角左下角右上角右下角这四个数的最小值,要你最大化矩形 的价值. 关键点是要想到把这些值排序 值从小到大考虑,比如说现在最小的值是(x1 ...

  4. BZOJ两水题连发~(BZOJ1854&&BZOJ1191)

    前言:两题都是省选题不过水的惊人,且都可以用二分图最大匹配做哎--- 1854: [Scoi2010]游戏 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: ...

  5. 没讲明白的水题orz

    有一道解释程序的水题没给非计算机专业的同学讲明白orz,在这里再练一下.. 源代码完全没有缩进真是难以忍受.. p.s.懂递归就不用看了#include <stdio.h> int n = ...

  6. bzoj 5090 组题

    题目大意: 一个数列,求一段长度不少于k的数 使平均值最大 思路: 把所有数列里的数,转换为(i,sum i)的点 然后求一个下凸包,在这个过程中对于长度特殊处理一下,使栈内至少有一段长度大于等于k ...

  7. BZOJ 2683: 简单题

    2683: 简单题 Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 913  Solved: 379[Submit][Status][Discuss] ...

  8. bzoj 4066: 简单题 kd-tree

    4066: 简单题 Time Limit: 50 Sec  Memory Limit: 20 MBSubmit: 234  Solved: 82[Submit][Status][Discuss] De ...

  9. bzoj 2510: 弱题 循环矩阵

    2510: 弱题 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 124  Solved: 61[Submit][Status][Discuss] De ...

随机推荐

  1. mac 中查看监听程序

    sudo lsof -nP -iTCP -sTCP:LISTEN | grep mysql

  2. Java Arrays.sort相关用法与重载

    Java Arrays.sort() Java中的数组排序函数, 头文件 import java.util.Arrays; 相关API Arrays.sort(arys[]) Arrays.sort( ...

  3. HTML5中Canvas概述

    一.HTML5 Canvas历史 Canvas的概念最初是由苹果公司提出的,用于在Mac OS X WebKit中创建控制板部件(dashboard widget).在Canvas出现之前,开发人员若 ...

  4. RequestMapping_HiddenHttpMethodFilter 过滤器

    [REST] 1.REST:即Representational State Transfer.(资源)表现层状态转化.是目前最流行的一种互联网软件架构.它结构清晰.符合标准.易于理解.扩展方便,所以得 ...

  5. Android BottomSheet:以选取图片为例(2)

     Android BottomSheet:以选取图片为例(2) 附录文章5简单介绍了常见的分享面板在BottomSheet中的具体应用.本文再以常见的选取图片为例写一个例子. 布局文件: < ...

  6. MaxScale初探

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://mrcto.blog.51cto.com/1923168/1437287 内容预览 ...

  7. B树、B-树、B+树、B*树介绍,和B+树更适合做文件索引的原因

    今天看数据库,书中提到:由于索引是采用 B 树结构存储的,所以对应的索引项并不会被删除,经过一段时间的增删改操作后,数据库中就会出现大量的存储碎片, 这和磁盘碎片.内存碎片产生原理是类似的,这些存储碎 ...

  8. [bzoj2038][2009国家集训队]小Z的袜子(hose)_莫队

    小Z的袜子 hose 2009-国家集训队 bzoj-2038 题目大意:给定一个n个袜子的序列,每个袜子有一个颜色.m次询问:每次询问一段区间中每种颜色袜子个数的平方和. 注释:$1\le n,m\ ...

  9. 洛谷——P1720 月落乌啼算钱

    题目背景 (本道题目木有以藏歌曲……不用猜了……) <爱与愁的故事第一弹·heartache>最终章. 吃完pizza,月落乌啼知道超出自己的预算了.为了不在爱与愁大神面前献丑,只好还是硬 ...

  10. iOS xmpp协议实现聊天之openfire的服务端配置(二)

    本篇主要说一下怎样利用命令行来正确配置MySql. 首先打开终端: 1.为mysql起一个别名 alias mysql=/usr/local/mysql/bin/mysql 2.创建mysql的管理员 ...