社区讨论
萌新刚学图论,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 条回复,欢迎继续交流。
正在加载回复...