\(\\\)

\(Description\)


对一长为\(N\)的数列\(A\)排序,不保证数列元素互异:

  • 数列\(A\)中\(A[1...i]\)的最大值不大于\(A[i+1…N]\)的最小值,我们就称元素\(i\)和\(i+1\)之间的位置为一个分隔点.

  • 当数列未排好序时,将每一个由分隔点分出的区间单独进行一次顺序扫描的冒泡排序,循环至数列排好序。

  • 形式化的代码可以描述成:

    1. work_counter = 0
    2. bubble_sort_pass (A) {
    3. for i = 0 to length(A)-2
    4. if A[i] > A[i+1], swap A[i] and A[i+1]
    5. }
    6. quickish_sort (A) {
    7. if length(A) = 1, return
    8. do {
    9. work_counter = work_counter + length(A)
    10. bubble_sort_pass(A)
    11. } while (no partition points exist in A)
    12. divide A at all partition points;
    13. recursively quickish_sort each piece
    14. }

求退出循环后\(work\_counter\)的值。

  • \(N\in [0,10^5]\),\(A_i\in [0,10^9]\)

\(\\\)

\(Solution\)


  • 注意到由定义的分隔点分开的每一个区间内,所有元素只会在这一区间内交换,而不会越过分隔点,所以对每一个区间单独冒泡排序与对整个数列冒泡排序是一样的。

  • 所以问题中计数的递归区间总长度,其实是每一个数字被比较的次数之和,其实就是每个数字被递归的层数之和。当一个数字不再被递归计算,当且仅当区间长度为\(1\),即左右都产生了分隔点。于是问题变为:计算每一个数左右都产生分隔点所需的递归次数之和。

  • 每一个数左右都产生分隔点的递归次数又可以看做两个分隔点产生的时间取\(max\),于是只需统计每一个分隔点产生的递归层数。

  • 回到分隔点定义,一个分割点产生,只需要两侧的元素都正确的分开,而不是两侧都排好序。所以一个分隔点产生的时间,是所有应该在左区间的右区间的数移到左区间的时间,和所有应该在右区间的左区间的数移到右区间的时间取最大值。注意到是单向冒泡排序,所以排序的瓶颈在于应当向前移动的那些数字,因为它们每次只会向前移动一个位置。所以我们需要统计离分隔点最远的应移到左区间的点,到分隔点的距离。

  • 于是排序后第一遍扫描统计每一个分隔点产生时间,第二遍扫描累加答案即可。要注意即使一个元素开始就在应该在的地方,即左右分隔点产生时间都为\(0\),也应该计数,因为运行代码中,开始需要将数列扫描一遍来确定是否需要递归。

\(\\\)

\(Code\)


  1. #include<cmath>
  2. #include<cstdio>
  3. #include<cctype>
  4. #include<cstdlib>
  5. #include<cstring>
  6. #include<iostream>
  7. #include<algorithm>
  8. #define N 100010
  9. #define R register
  10. #define gc getchar
  11. using namespace std;
  12. typedef long long ll;
  13. inline ll rd(){
  14. ll x=0; bool f=0; char c=gc();
  15. while(!isdigit(c)){if(c=='-')f=1;c=gc();}
  16. while(isdigit(c)){x=(x<<1)+(x<<3)+(c^48);c=gc();}
  17. return f?-x:x;
  18. }
  19. ll n,ans=1,t[N];
  20. struct seq{ll x,p;}s[N];
  21. inline bool cmp(seq x,seq y){
  22. return x.x==y.x?x.p<y.p:x.x<y.x;
  23. }
  24. int main(){
  25. n=rd();
  26. if(n==0){puts("0");return 0;}
  27. for(R ll i=1;i<=n;++i){s[i].x=rd();s[i].p=i;}
  28. sort(s+1,s+1+n,cmp);
  29. for(R ll i=1,mx=0;i<=n;++i){
  30. mx=max(mx,s[i].p); t[i]=mx-i;
  31. }
  32. ans=t[1];
  33. for(R ll i=2;i<=n;++i) ans+=max(t[i-1],max(t[i],1ll));
  34. printf("%lld\n",max(ans,n));
  35. return 0;
  36. }

[ USACO 2018 OPEN ] Out of Sorts (Platinum)的更多相关文章

  1. [ USACO 2018 OPEN ] Out of Sorts (Gold)

    \(\\\) \(Description\) 运行以下代码对一长为\(N\)的数列\(A\)排序,不保证数列元素互异: cnt = 0 sorted = false while (not sorted ...

  2. [ USACO 2018 OPEN ] Out of Sorts (Silver)

    \(\\\) \(Description\) 运行以下代码对一长为\(N\)的数列\(A\)排序,不保证数列元素互异: cnt = 0 sorted = false while (not sorted ...

  3. 【二分+拓扑排序】Milking Order @USACO 2018 US Open Contest, Gold/upc_exam_6348

    目录 Milking Order @USACO 2018 US Open Contest, Gold/upc_exam_6348 PROBLEM 题目描述 输入 输出 样例输入 样例输出 提示 MEA ...

  4. [USACO 2018 Open Contest]作业总结

    t1-Out of Sorts 题目大意 将最大的数冒泡排序到最后需要多少次操作. 分析 排序后判断距离. ac代码 #include<bits/stdc++.h> #define N 1 ...

  5. [USACO 2018 Feb Gold] Tutorial

    Link: USACO 2018 Feb Gold 传送门 A: $dp[i][j][k]$表示前$i$个中有$j$个0且末位为$k$的最优解 状态数$O(n^3)$ #include <bit ...

  6. [USACO 2018 Jan Gold] Tutorial

    Link: USACO 2018 Jan Gold 传送门 A: 对于不同的$k$,发现限制就是小于$k$的边不能走 那么此时的答案就是由大于等于$k$的边形成的图中$v$所在的连通块除去$v$的大小 ...

  7. [LOJ#2386]. 「USACO 2018.01 Platinum」Cow at Large[点分治]

    题意 题目链接 分析 假设当前的根为 rt ,我们能够在奶牛到达 \(u\) 之时拦住它,当且仅当到叶子节点到 \(u\) 的最短距离 \(mn_u \le dis_u\) .容易发现,合法的区域是许 ...

  8. 【杂题1】USACO 2018 Open Contest-练习

    https://www.xoj.red/contests/show/1231 下面会写一些题目的解析什么的,当然不会粘贴题目只是简单提一下 (部分题目简单的题目就不概括了) 其实难度应该前面比较低. ...

  9. [USACO 2018 December Contest]作业总结

    t1 Convention 题目大意 每一头牛都有一个来的时间,一共有\(n\)辆车,求出等待时间最长的那头牛等待的最小时间. 解法 第一眼看到这道题还以为是\(2018noip\)普及组的t3魔鬼题 ...

随机推荐

  1. tyvj2059 元芳看电影

    描述 神探狄仁杰电影版首映这天,狄仁杰.李元芳和狄如燕去看电影.由于人实在是太多了,入场的队伍变得十分不整齐,一个人的前面可能会出现并排的好多人.“元芳,这队伍你怎么看?”“大人,卑职看不出这队伍是怎 ...

  2. HDU A/B 扩展欧几里得

    Problem Description 要求(A/B)%9973,但由于A很大,我们只给出n(n=A%9973)(我们给定的A必能被B整除,且gcd(B,9973) = 1).   Input 数据的 ...

  3. 洛谷——P1255 数楼梯

    题目描述 楼梯有N阶,上楼可以一步上一阶,也可以一步上二阶. 编一个程序,计算共有多少种不同的走法. 输入输出格式 输入格式: 一个数字,楼梯数. 输出格式: 走的方式几种. 输入输出样例 输入样例# ...

  4. 【APIO2012】【BZOJ2809】派遣dispatching

    2809: [Apio2012]dispatching Time Limit: 10 Sec Memory Limit: 128 MB Submit: 1932 Solved: 967 [Submit ...

  5. RxJava系列之二 变换类操作符具体解释1

    1.回想 上一篇文章我们主要介绍了RxJava , RxJava 的Observables和 RxJava的just操作符.以及RxJava一些经常使用的操作. 没看过的抓紧点我去看吧. 事实上RxJ ...

  6. HDU 4499 Cannon (暴力搜索)

    题意:在n*m的方格里有t个棋子,问最多能放多少个炮且每一个炮不能互相攻击(炮吃炮) 炮吃炮:在同一行或同一列且中间有一颗棋子. #include <stdio.h> #include & ...

  7. HDU 1421 搬寝室 (线性dp 贪心预处理)

    搬寝室 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submis ...

  8. LeetCode 977. Squares of a Sorted Array (有序数组的平方)

    题目标签:Array 题目给了我们一组 从小到大的 integers,让我们平方数字 并且 也排序成 从小到达. 因为有负数在里面,平方后,负数在array的位置会变动. 可以设left 和 righ ...

  9. 5分钟Serverless实践 | 构建无服务器图片鉴黄Web应用

    Serverless是什么 Serverless中文译为“无服务器”,最早可以追溯到2012年Ken Fromm发表的<Why The Future Of Software And Apps I ...

  10. struts2 一个CRUD的BaseAction

    在struts2 in action中所见,这样封装后省去了大部分crud反复代码.尽管还不能理悟.先记下来. abstract class BaseAction extends ActionSupp ...