社区讨论

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 条回复,欢迎继续交流。

正在加载回复...