4961:[CSP-J 2021] 插入排序
文件提交:无需freopen
内存限制:512 MB
时间限制:1.000 S
评测方式:普通裁判
金币值:
命题人:
提交:1
解决:0
题目描述
# [CSP-J 2021] 插入排序
题目描述
插入排序是一种非常常见且简单的排序算法。小 Z 是一名大一的新生,今天 H 老师刚刚在上课的时候讲了插入排序算法。 假设比较两个元素的时间为 $\mathcal O(1)$,则插入排序可以以 $\mathcal O(n^2)$ 的时间复杂度完成长度为 $n$ 的数组的排序。不妨假设这 $n$ 个数字分别存储在 $a_1, a_2, \ldots, a_n$ 之中,则如下伪代码给出了插入排序算法的一种最简单的实现方式: 这下面是 C/C++ 的示范代码: ```cpp for (int i = 1; i <= n; i++) for (int j = i; j >= 2; j--) if (a[j] < a[j-1]) { int t = a[j-1]; a[j-1] = a[j]; a[j] = t; } ``` 这下面是 Pascal 的示范代码: ```pascal for i:=1 to n do for j:=i downto 2 do if a[j]输入格式 第一行,包含两个正整数 $n, Q$,表示数组长度和操作次数。 第二行,包含 $n$ 个空格分隔的非负整数,其中第 $i$ 个非负整数表示 $a_i$。 接下来 $Q$ 行,每行 $2 \sim 3$ 个正整数,表示一次操作,操作格式见【**题目描述**】。输出格式
对于每一次类型为 $2$ 的询问,输出一行一个正整数表示答案。3 4
3 2 1
2 3
1 3 2
2 2
2 3
1
1
2