社区讨论
8分求调
P7910[CSP-J 2021] 插入排序参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @m1xpoht3
- 此快照首次捕获于
- 2024/10/06 23:01 去年
- 此快照最后确认于
- 2025/11/04 17:47 4 个月前
CPP
#include<bits/stdc++.h>
using namespace std;
const int MAXN = 8005;
int n, q, x, y, z;
struct node
{
int m, id;
}a[MAXN], b[MAXN];
int main()
{
cin >> n >> q;
for(int i = 1; i <= n; i++)
{
cin >> a[i].m;
b[i].m = a[i].m;
b[i].id = i;
a[i].id = i;
}
while(q--)
{
cin >> x;
if(x == 1)
{
cin >> y >> z;
for(int i = 1; i <= n; i++) a[i].m = b[i].m;
for(int i = 1; i <= n; i++)
{
if(a[i].m == b[y].m) a[i].m = z;
a[i].id = i;
}
}
else
{
cin >> y;
for(int i = 1; i <= n; i++)
{
for(int j = i; j >= 2; j--)
{
if(a[j].m < a[j - 1].m)
{
int t = a[j - 1].m, tt = a[j - 1].id;
a[j - 1].m = a[j].m;
a[j - 1].id = a[j].id;
a[j].m = t;
a[j].id = tt;
}
}
}
for(int i = 1; i <= n; i++)
{
if(a[i].id == y)
{
cout << i << endl;
break;
}
}
}
}
return 0;
}
回复
共 0 条回复,欢迎继续交流。
正在加载回复...