中文题面:

留意着农场之外的长期职业生涯的可能性,奶牛Bessie开始在不同的在线编程网站上学习算法。

她到目前为止最喜欢的算法是“冒泡排序”。这是Bessie的对长度为N N的数组A A进行排序的奶牛码实现。

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

显然,奶牛码中的“moo”指令的作用只是输出“moo”。奇怪的是,Bessie看上去执着于在她的代码中的不同位置使用这个语句。

给定一个输入数组,请预测Bessie的代码会输出多少次“moo”。

输入格式(文件名:sort.in):

输入的第一行包含N N(1≤N≤100,000 1≤N≤100,000)。接下来N N行描述了A[0]…A[N−1] A[0]…A[N−1],每个数都是一个范围为0…10 9 0…109的整数。输入数据不保证各不相同。

输出格式(文件名:sort.out):

输出“moo”被输出的次数。

输入样例:
5
1
5
3
8
2

输出样例:
4

供题:Brian Dean

官方题解:

#include <cstdio>
#include <algorithm>
using namespace std;

struct Entry {
  int index;
  int value;
};

Entry entries[100000];

int main() {
  int n;
  scanf("%d", &n);

  for (int i = 0; i < n; i++) {
    entries[i].index = i;
    scanf("%d", &entries[i].value);
  }

  sort(entries, entries + n, [](Entry a, Entry b) {
    // Break ties by making the smaller element be whichever
    // element was first in the array originally.
    return a.value < b.value || (a.value == b.value && a.index < b.index);
  });

  int answer = 0;
  for (int j = 0; j < n; j++) {
    // In terms of the notation from the above analysis, we have,
    // entries[j].index = i
    // j = a_i
    answer = max(answer, entries[j].index - j);
  }

  printf("%d\n", answer + 1);
}