社区讨论

萌新刚学图论,vector不会用求助

灌水区参与者 5已保存回复 14

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
14 条
当前快照
1 份
快照标识符
@lo1664vv
此快照首次捕获于
2023/10/22 15:50
2 年前
此快照最后确认于
2023/11/02 15:25
2 年前
查看原帖
RT,程序进行到第31行时编译器报错了,说vector越界。为啥呀
CPP
#include<bits/stdc++.h>
using namespace std;
struct edge {
	int from, to;
	edge(int a, int b) { from = a; to = b; }
};
vector<edge>G[2000003];
int n;long long m;
int t;
int a[2000006];
int maxi, maxn;
int main() {
	ios::sync_with_stdio(0);
	cin >> t;
	while (t--) {
		cin >> n >> m;
		
		for (int i = 1; i <= n; i++) {
			cin >> a[i];
			if (a[i] > maxn) {
				maxn = a[i];
				maxi = i;
			}
		}
		int x, y;
		for (int i = 0; i < n - 1; i++) {
			cin >> x >> y;
			G[x].push_back(edge(x, y));
		}
		int mn = -1, mi = -1;
		for (int i = 0; i < G[maxi].size(); i++) {
			if (a[G[maxi][i].to] > mn) {
				mn = a[G[maxi][i].to];
				mi = G[maxi][i].to;
			}
		}
		m -= a[maxi] - a[G[maxi][mi].to];
		if (m > 0)a[G[maxi][mi].to] = a[maxi];
		else {
			cout << maxi << endl;
			for (int i = 1; i <= n; i++)G[i].clear();
			continue;
		}
		if (mi < maxi) {
			if (m % 2 == 0)cout << mi << endl;
			else cout << maxi << endl;
		}
		else {
			if (m % 2 == 1)cout << mi << endl;
			else cout << maxi << endl;
		}
		for (int i = 1; i <= n; i++)G[i].clear();
	}
}

回复

14 条回复,欢迎继续交流。

正在加载回复...