제출 #1302615

#제출 시각아이디문제언어결과실행 시간메모리
1302615witek_cppEaster Eggs (info1cup17_eastereggs)C++20
컴파일 에러
0 ms0 KiB
#include <iostream>
#include <vector>
#include <algorithm>
#include <unordered_set>

using namespace std;
typedef long long ll;

#define st first
#define nd second
#define f(a, c, b) for (int a = c; b > a; a++)
#define pb push_back
#define all(a) a.begin(), a.end()
#define sz(a) int(a.size())
#define DUZO 1000000000000000000
using pii = pair<int, int>;
using pll = pair<ll, ll>;
using vi = vector<int>;
using vvi = vector<vi>;

int query(vector<int> islands);

vvi g;
vi ak;
int mid;
int ile_poszlo;
vi pyt;

/*int query(vi a) {
	for (int ele: a) {
		if (ele == 3) return 1;
	}
	return 0;
}*/

void dfs_pyt(int v, int p) {
	if (ile_poszlo >= mid) return;
	if (ak[v]) {
		ile_poszlo++;
	}
	pyt.pb(v);
	for (int u: g[v]) {
		if (u == p) continue;
		dfs_pyt(u, v);
	}
}

int findEgg(int n, vector<pii> kr) {
	g = {};
	g.resize(n + 1);
	for (auto [u, v]: kr) {
		g[u].pb(v);
		g[v].pb(u);
	}
	ak = {};
	ak.resize(n + 1, 1); //czy jest w potencjalnym solvie
	unordered_set<int> zb;
	f(i, 1, n+ 1) zb.insert(i);
	while (sz(zb)>1) {
		mid = sz(zb)/2;
		pyt = {};
		ile_poszlo = 0;
		dfs_pyt(*(zb.begin()), 0);
		int val = query(pyt);
		if (val) {
			f(i, 1, n+ 1) ak[i] = 0;
			unordered_set<int> lol;
			for (int ele: pyt) {
				if (zb.cound(ele)) {
					lol.insert(ele);
				}
				ak[ele] = 1;
			}
			zb= lol;
		} else {
			for (int ele: pyt) {
				zb.erase(ele);
				ak[ele] = 0;
			}
		}
	}
	return *(zb.begin());
}

/*int main() {
	int n = 7;
	vector<pii> kr = {{1, 2}, {1, 3}, {2, 4}, {2, 5}, {4, 6}, {3, 7}};
	cout << findEgg(n, kr) << "\n";
}*/

컴파일 시 표준 에러 (stderr) 메시지

eastereggs.cpp: In function 'int findEgg(int, std::vector<std::pair<int, int> >)':
eastereggs.cpp:69:40: error: 'class std::unordered_set<int>' has no member named 'cound'; did you mean 'count'?
   69 |                                 if (zb.cound(ele)) {
      |                                        ^~~~~
      |                                        count