답안 #984891

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
984891 2024-05-17T08:00:07 Z javotaz 사이버랜드 (APIO23_cyberland) C++17
컴파일 오류
0 ms 0 KB
// In the Name of Allah

#include<bits/stdc++.h>
using namespace std;

#pragma GCC optimize("Ofast,unroll-loops,fast-math")
//#pragma GCC target("sse,sse2,sse3,ssse3,sse4.1,sse4.2,avx,avx2,popcnt,tune=native")

typedef long long ll;
typedef pair<double, int> pd;

#define F first
#define S second
#define pii pair<int, int>
#define pb push_back
#define pp pop_back
#define all(x) x.begin(), x.end()

const int N = 1e5 + 12, K = 76;
vector<pii> g[N];
int n, m, k, h, a[N];
double ans;
bool mrk[N][K], t[N]; 

void dfs(int u) {
	t[u] = true;
	for (auto i: g[u])
		if (!t[i])
			dfs(i);
}

void find_ans() {
	dfs(0);
	ans = -1;
	if (!t[h]) 
		return;
	priority_queue<pd, vector<pd>, greater<pd>> q;
	q.push({0, 0});
	for (int i = 1; i < n; i++)
		if (!a[i] && t[i])
			q.push({0, i});
	while (!q.empty()) {
		auto tmp = q.top();
		q.pop();
		int u = tmp.S % n, ck = tmp.S / n;
		double w = tmp.F;
		if (u == h) {
			if (ans == -1)
				ans = w;
			else
				ans = min(ans, w);
			mrk[u][ck] = true;
		}
		if (mrk[u][ck])
			continue;
		mrk[u][ck] = true;
		for (auto i: g[u])
			if (a[i.F] && !mrk[i.F][ck + (a[i.F] == 2)]) { 
				if (a[i.F] == 1)
					q.push({w + i.S, i.F + ck * n});
				else if (ck + 1 <= k)
					q.push({(w + i.S) / 2.0, i.F + (ck + 1) * n});
			}
	}
}

double solve(int ns, int ms, int ks, int hs, vector<int> xs, vector<int> ys, vector<int> ws, vector<int> as) {
	n = ns, m = ms, k = min(ks, 75), h = hs;
	for (int i = 0; i < m; i++)
		g[xs[i]].pb({ys[i], ws[i]}), g[ys[i]].pb({xs[i], ws[i]});
	for (int i = 0; i < n; i++)
		a[i] = as[i];
	find_ans();
	for (int i = 0; i < n; i++) {
		g[i].clear();
		for (int j = 0; j <= k; ++j)
			mrk[i][j] = false;
	}
	return ans;
}

Compilation message

cyberland.cpp: In function 'void dfs(int)':
cyberland.cpp:28:9: error: no match for 'operator[]' (operand types are 'bool [100012]' and 'std::pair<int, int>')
   28 |   if (!t[i])
      |         ^
cyberland.cpp:29:8: error: cannot convert 'std::pair<int, int>' to 'int'
   29 |    dfs(i);
      |        ^
      |        |
      |        std::pair<int, int>
cyberland.cpp:25:14: note:   initializing argument 1 of 'void dfs(int)'
   25 | void dfs(int u) {
      |          ~~~~^