Submission #5646924


Source Code Expand

#include <algorithm>
#include <cstdio>
#include <vector>
#include <set>
int fa[100005], arr[100005];
std::vector<int> vec[100005];
std::multiset<int> se;
int getfa(int u) { return u == fa[u] ? u : fa[u] = getfa(fa[u]); }
int main()
{
	// freopen("K.in", "r", stdin);
	int n, m;
	scanf("%d%d", &n, &m);
	if (m == n - 1)
	{
		puts("0");
		return 0;
	}
	for (int i = 0; i < n; i++)
	{
		scanf("%d", arr + i);
		se.insert(arr[i]);
		fa[i] = i;
	}
	for (int i = 0; i < m; i++)
	{
		int u, v;
		scanf("%d%d", &u, &v);
		fa[getfa(u)] = getfa(v);
	}
	for (int i = 0; i < n; i++)
		vec[getfa(i)].push_back(arr[i]);
	long long ans = 0;
	for (int i = 0; i < n; i++)
	{
		if (vec[i].empty())
			continue;
		int x = *std::min_element(vec[i].begin(), vec[i].end());
		ans += x;
		se.erase(se.find(x));
	}
	for (int i = 0; i < n - m - 2; i++)
	{
		if (se.empty())
		{
			puts("Impossible");
			return 0;
		}
		ans += *se.begin();
		se.erase(se.begin());
	}
	printf("%lld\n", ans);
	return 0;
}

Submission Info

Submission Time
Task D - Forest
User diamond_duke
Language C++14 (GCC 5.4.1)
Score 600
Code Size 1033 Byte
Status AC
Exec Time 82 ms
Memory 11136 KB

Compile Error

./Main.cpp: In function ‘int main()’:
./Main.cpp:13:23: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d%d", &n, &m);
                       ^
./Main.cpp:21:23: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d", arr + i);
                       ^
./Main.cpp:28:24: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d%d", &u, &v);
                        ^

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 600 / 600
Status
AC × 3
AC × 52
Set Name Test Cases
Sample 0_000.txt, 0_001.txt, 0_002.txt
All 0_000.txt, 0_001.txt, 0_002.txt, 1_003.txt, 1_004.txt, 1_005.txt, 1_006.txt, 1_007.txt, 1_008.txt, 1_009.txt, 1_010.txt, 1_011.txt, 1_012.txt, 1_013.txt, 1_014.txt, 1_015.txt, 1_016.txt, 1_017.txt, 1_018.txt, 1_019.txt, 1_020.txt, 1_021.txt, 1_022.txt, 1_023.txt, 1_024.txt, 1_025.txt, 1_026.txt, 1_027.txt, 1_028.txt, 1_029.txt, 1_030.txt, 1_031.txt, 1_032.txt, 1_033.txt, 1_034.txt, 1_035.txt, 1_036.txt, 1_037.txt, 1_038.txt, 1_039.txt, 1_040.txt, 1_041.txt, 1_042.txt, 1_043.txt, 1_044.txt, 1_045.txt, 1_046.txt, 1_047.txt, 1_048.txt, 1_049.txt, 1_050.txt, 1_051.txt
Case Name Status Exec Time Memory
0_000.txt AC 2 ms 2560 KB
0_001.txt AC 2 ms 2560 KB
0_002.txt AC 2 ms 2560 KB
1_003.txt AC 2 ms 2560 KB
1_004.txt AC 74 ms 11136 KB
1_005.txt AC 74 ms 11136 KB
1_006.txt AC 75 ms 11136 KB
1_007.txt AC 74 ms 11008 KB
1_008.txt AC 77 ms 10752 KB
1_009.txt AC 79 ms 9728 KB
1_010.txt AC 74 ms 9212 KB
1_011.txt AC 73 ms 9084 KB
1_012.txt AC 72 ms 8704 KB
1_013.txt AC 70 ms 8704 KB
1_014.txt AC 2 ms 2560 KB
1_015.txt AC 76 ms 11136 KB
1_016.txt AC 74 ms 11136 KB
1_017.txt AC 74 ms 11136 KB
1_018.txt AC 74 ms 11136 KB
1_019.txt AC 78 ms 10880 KB
1_020.txt AC 78 ms 9728 KB
1_021.txt AC 75 ms 9340 KB
1_022.txt AC 73 ms 9084 KB
1_023.txt AC 71 ms 8700 KB
1_024.txt AC 71 ms 8700 KB
1_025.txt AC 2 ms 2560 KB
1_026.txt AC 21 ms 6784 KB
1_027.txt AC 20 ms 6784 KB
1_028.txt AC 20 ms 6784 KB
1_029.txt AC 21 ms 6656 KB
1_030.txt AC 22 ms 6528 KB
1_031.txt AC 25 ms 6016 KB
1_032.txt AC 25 ms 5888 KB
1_033.txt AC 24 ms 5760 KB
1_034.txt AC 24 ms 5632 KB
1_035.txt AC 25 ms 5632 KB
1_036.txt AC 2 ms 2560 KB
1_037.txt AC 44 ms 11136 KB
1_038.txt AC 43 ms 11136 KB
1_039.txt AC 43 ms 11136 KB
1_040.txt AC 45 ms 11136 KB
1_041.txt AC 47 ms 10880 KB
1_042.txt AC 53 ms 9728 KB
1_043.txt AC 53 ms 9340 KB
1_044.txt AC 52 ms 9084 KB
1_045.txt AC 51 ms 8700 KB
1_046.txt AC 51 ms 8700 KB
1_047.txt AC 2 ms 2560 KB
1_048.txt AC 79 ms 9728 KB
1_049.txt AC 79 ms 9728 KB
1_050.txt AC 81 ms 9728 KB
1_051.txt AC 82 ms 9728 KB