Submission #2201017
Source Code Expand
#define _CRT_SECURE_NO_WARNINGS
#include <cstdio>
#include <vector>
#include <string>
#include <iostream>
#include <algorithm>
#include <map>
#include <iterator>
#include <functional>
#include <set>
#include <stack>
#include <queue>
#include <deque>
#include <fstream>
#include <iomanip>
#include <numeric>
#include <cmath>
#include <list>
#include <sstream>
#include <cstring>
#include <stdio.h>
#include <complex>
using namespace std;
#pragma GCC optimize("O3")
#pragma GCC target("sse4")
typedef long double LD;
typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int, int> PII;
typedef pair<LD, LD> PDD;
typedef pair<LL, LL> PLL;
typedef vector<int> VI;
typedef vector<LL> VLL;
typedef vector<char> VCH;
typedef vector<LD> VLD;
typedef vector<string> VS;
typedef vector<VS> VSS;
typedef vector<VI> VVI;
typedef vector<VLL> VVLL;
typedef vector<VCH> VVCH;
typedef vector<PII> VPII;
typedef vector<PLL> VPLL;
typedef vector<PDD> VPDD;
#define MP make_pair
#define PB push_back
#define X first
#define Y second
#define next fake_next
#define prev fake_prev
#define left fake_left
#define right fake_right
#define FOR(i, a, b) for(LL i = (a); i < (b); ++i)
#define RFOR(i, b, a) for(int i = (b) - 1; i >= (a); --i)
#define REP(i, t) FOR(i, 0, t)
#define ALL(a) a.begin(), a.end()
#define SZ(a) (int)((a).size())
#define FILL(a, value) memset(a, value, sizeof(a))
const LD PI = acos(-1.0);
const LD EPS = 1e-9;
const LL INF = 1e9;
const LL LINF = 1e18;
const LL mod = 1000000007;
const LL MAXN = 1e5 + 47;
const LL MAX = 1e5 + 47;
LL n;
VI g[MAX];
char used[MAX];
bool dw;
void dfs(int v, char color = 1)
{
used[v] = color;
for (auto i : g[v])
{
if (used[i] == 0)
dfs(i, 3 - color);
if (used[i] == used[v])
dw = 0;
}
}
int main()
{
ios_base::sync_with_stdio(0), cin.tie(0), cout.tie(0);
//freopen("In.txt", "r", stdin);
LL u, v, m;
cin >> n >> m;
FOR(i, 0, m)
{
cin >> u >> v;
--u; --v;
g[u].push_back(v);
g[v].push_back(u);
}
LL l = 0, k = 0;
LL ans = 0;
m = n;
FOR(i,0,n)
if (SZ(g[i]) == 0)
{
ans += 2LL * m - 1;
--m;
}
else
{
if (used[i])
continue;
dw = 1;
dfs(i, 1);
if (dw)
++k;
else
++l;
}
ans += 2 * k*k;
ans += l * l;
ans += 2 * k*l;
cout << ans;
cin >> n;
return 0;
}
Submission Info
Submission Time |
|
Task |
C - Squared Graph |
User |
vjudge5 |
Language |
C++14 (GCC 5.4.1) |
Score |
800 |
Code Size |
2288 Byte |
Status |
AC |
Exec Time |
73 ms |
Memory |
8576 KB |
Judge Result
Set Name |
Sample |
All |
Score / Max Score |
0 / 0 |
800 / 800 |
Status |
|
|
Set Name |
Test Cases |
Sample |
sample1.txt, sample2.txt |
All |
sample1.txt, sample2.txt, in1.txt, in10.txt, in11.txt, in12.txt, in13.txt, in14.txt, in15.txt, in16.txt, in17.txt, in18.txt, in19.txt, in2.txt, in20.txt, in21.txt, in22.txt, in23.txt, in24.txt, in25.txt, in26.txt, in27.txt, in28.txt, in3.txt, in4.txt, in5.txt, in6.txt, in7.txt, in8.txt, in9.txt, sample1.txt, sample2.txt |
Case Name |
Status |
Exec Time |
Memory |
in1.txt |
AC |
2 ms |
2560 KB |
in10.txt |
AC |
3 ms |
2560 KB |
in11.txt |
AC |
2 ms |
2560 KB |
in12.txt |
AC |
19 ms |
5760 KB |
in13.txt |
AC |
19 ms |
5888 KB |
in14.txt |
AC |
36 ms |
5888 KB |
in15.txt |
AC |
5 ms |
3072 KB |
in16.txt |
AC |
27 ms |
4352 KB |
in17.txt |
AC |
21 ms |
5248 KB |
in18.txt |
AC |
50 ms |
6400 KB |
in19.txt |
AC |
39 ms |
6272 KB |
in2.txt |
AC |
2 ms |
2560 KB |
in20.txt |
AC |
39 ms |
6272 KB |
in21.txt |
AC |
73 ms |
8576 KB |
in22.txt |
AC |
47 ms |
5760 KB |
in23.txt |
AC |
34 ms |
4864 KB |
in24.txt |
AC |
3 ms |
2688 KB |
in25.txt |
AC |
72 ms |
8576 KB |
in26.txt |
AC |
2 ms |
2560 KB |
in27.txt |
AC |
3 ms |
2688 KB |
in28.txt |
AC |
71 ms |
8576 KB |
in3.txt |
AC |
2 ms |
2560 KB |
in4.txt |
AC |
2 ms |
2560 KB |
in5.txt |
AC |
49 ms |
5376 KB |
in6.txt |
AC |
4 ms |
2944 KB |
in7.txt |
AC |
4 ms |
2816 KB |
in8.txt |
AC |
8 ms |
3584 KB |
in9.txt |
AC |
22 ms |
4480 KB |
sample1.txt |
AC |
2 ms |
2560 KB |
sample2.txt |
AC |
2 ms |
2560 KB |