Submission #932173

# Submission time Handle Problem Language Result Execution time Memory
932173 2024-02-23T04:12:37 Z Muhammad_Aneeq Graph (BOI20_graph) C++17
58 / 100
645 ms 17100 KB
  /*
  بسم الله الرحمن الرحيم
  Author:
                            (:Muhammad Aneeq:)
  */
#include <iostream>
#include <vector>
#include <bitset>
#include <queue>
using namespace std;
int const N=1e5+10;
vector<pair<int,int>>nei[N]={};
float val[N]={},ansval[N]={};
bitset<N>vis;
vector<vector<int>>f;
float mx=1e9+10;
int n,m;
inline bool bfs(int u)
{
  queue<int>g;
  g.push(u);
  while (g.size())
  {
    int u=g.front();
    g.pop();
    for (auto [i,j]:nei[u])
    {
      if (val[i]==-1e9)
      {
        val[i]=j-val[u];
        g.push(i);
      }
      else if (val[i]+val[u]!=j)
        return 0;
    }
  }
  return 1;
}
void dfs(int x)
{
  vis[x]=1;
  f.back().push_back(x);
  for (auto [i,j]:nei[x])
  {
    if (!vis[i])
      dfs(i);
  }
}
inline void solve()
{
  cin>>n>>m;
  for (int i=0;i<m;i++)
  {
    int u,v,t;
    cin>>u>>v>>t;
    nei[u].push_back({v,t});
    nei[v].push_back({u,t});
  }
  for (int i=1;i<=n;i++)
  {
    if (!vis[i])
    {
      f.push_back({});
      dfs(i);
    }
  }
  for (int i=1;i<=n;i++)
  {
    val[i]=-1e9;
    ansval[i]=-1e9;
  }
  for (auto i:f)
  {
    int r=i[0];
    float mx=1e9+10;
    for (float j=-75;j<=25;j+=0.5)
    {
      val[r]=j;
      if (bfs(r))
      {
        float z=0;
        for (auto k:i)
          z+=abs(val[k]);
        if (z<mx)
        {
          mx=z;
          for (auto k:i)
            ansval[k]=val[k];
        }
      }
      for (auto k:i)
        val[k]=-1e9;
    }
    if (mx==1e9+10)
    {
      cout<<"NO\n";return;
    }
  }
  for (int i=1;i<=n;i++)
  {
    if (ansval[i]==-1e9)
    {
      cout<<"NO\n";return;
    }
  }
  cout<<"YES\n";
  for (int i=1;i<=n;i++)
    cout<<ansval[i]<<' ';
  cout<<endl;
}
int main()
{
    ios_base::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL);
        solve();
}
# Verdict Execution time Memory Grader output
1 Correct 1 ms 3416 KB answer = YES
2 Correct 2 ms 3420 KB answer = YES
3 Correct 1 ms 3372 KB answer = YES
4 Correct 1 ms 3420 KB answer = NO
5 Correct 2 ms 3420 KB answer = YES
6 Correct 2 ms 3420 KB answer = YES
7 Correct 1 ms 3420 KB answer = YES
8 Correct 2 ms 3420 KB answer = YES
9 Correct 1 ms 3420 KB answer = NO
10 Correct 1 ms 3420 KB answer = YES
11 Correct 2 ms 3420 KB answer = YES
12 Correct 1 ms 3420 KB answer = NO
13 Correct 1 ms 3420 KB answer = YES
14 Correct 1 ms 3420 KB answer = YES
15 Correct 1 ms 3420 KB answer = YES
16 Correct 1 ms 3420 KB answer = YES
17 Correct 1 ms 3420 KB answer = YES
18 Correct 1 ms 3420 KB answer = YES
19 Correct 1 ms 3420 KB answer = YES
20 Correct 1 ms 3420 KB answer = YES
21 Correct 1 ms 3416 KB answer = YES
22 Correct 1 ms 3420 KB answer = NO
23 Correct 1 ms 3420 KB answer = NO
# Verdict Execution time Memory Grader output
1 Correct 1 ms 3416 KB answer = YES
2 Correct 2 ms 3420 KB answer = YES
3 Correct 1 ms 3372 KB answer = YES
4 Correct 1 ms 3420 KB answer = NO
5 Correct 2 ms 3420 KB answer = YES
6 Correct 2 ms 3420 KB answer = YES
7 Correct 1 ms 3420 KB answer = YES
8 Correct 2 ms 3420 KB answer = YES
9 Correct 1 ms 3420 KB answer = NO
10 Correct 1 ms 3420 KB answer = YES
11 Correct 2 ms 3420 KB answer = YES
12 Correct 1 ms 3420 KB answer = NO
13 Correct 1 ms 3420 KB answer = YES
14 Correct 1 ms 3420 KB answer = YES
15 Correct 1 ms 3420 KB answer = YES
16 Correct 1 ms 3420 KB answer = YES
17 Correct 1 ms 3420 KB answer = YES
18 Correct 1 ms 3420 KB answer = YES
19 Correct 1 ms 3420 KB answer = YES
20 Correct 1 ms 3420 KB answer = YES
21 Correct 1 ms 3416 KB answer = YES
22 Correct 1 ms 3420 KB answer = NO
23 Correct 1 ms 3420 KB answer = NO
24 Correct 1 ms 3416 KB answer = YES
25 Correct 1 ms 3416 KB answer = YES
26 Correct 2 ms 3420 KB answer = YES
27 Correct 1 ms 3420 KB answer = YES
28 Correct 1 ms 3420 KB answer = YES
29 Correct 1 ms 3416 KB answer = YES
30 Correct 1 ms 3420 KB answer = NO
31 Correct 1 ms 3420 KB answer = YES
32 Correct 1 ms 3420 KB answer = YES
33 Correct 1 ms 3420 KB answer = YES
34 Correct 1 ms 3420 KB answer = YES
35 Correct 1 ms 3420 KB answer = YES
36 Correct 1 ms 3420 KB answer = YES
# Verdict Execution time Memory Grader output
1 Correct 1 ms 3416 KB answer = YES
2 Correct 2 ms 3420 KB answer = YES
3 Correct 1 ms 3372 KB answer = YES
4 Correct 1 ms 3420 KB answer = NO
5 Correct 2 ms 3420 KB answer = YES
6 Correct 2 ms 3420 KB answer = YES
7 Correct 1 ms 3420 KB answer = YES
8 Correct 2 ms 3420 KB answer = YES
9 Correct 1 ms 3420 KB answer = NO
10 Correct 1 ms 3420 KB answer = YES
11 Correct 2 ms 3420 KB answer = YES
12 Correct 1 ms 3420 KB answer = NO
13 Correct 1 ms 3420 KB answer = YES
14 Correct 1 ms 3420 KB answer = YES
15 Correct 1 ms 3420 KB answer = YES
16 Correct 1 ms 3420 KB answer = YES
17 Correct 1 ms 3420 KB answer = YES
18 Correct 1 ms 3420 KB answer = YES
19 Correct 1 ms 3420 KB answer = YES
20 Correct 1 ms 3420 KB answer = YES
21 Correct 1 ms 3416 KB answer = YES
22 Correct 1 ms 3420 KB answer = NO
23 Correct 1 ms 3420 KB answer = NO
24 Correct 1 ms 3416 KB answer = YES
25 Correct 1 ms 3416 KB answer = YES
26 Correct 2 ms 3420 KB answer = YES
27 Correct 1 ms 3420 KB answer = YES
28 Correct 1 ms 3420 KB answer = YES
29 Correct 1 ms 3416 KB answer = YES
30 Correct 1 ms 3420 KB answer = NO
31 Correct 1 ms 3420 KB answer = YES
32 Correct 1 ms 3420 KB answer = YES
33 Correct 1 ms 3420 KB answer = YES
34 Correct 1 ms 3420 KB answer = YES
35 Correct 1 ms 3420 KB answer = YES
36 Correct 1 ms 3420 KB answer = YES
37 Correct 2 ms 3420 KB answer = YES
38 Correct 1 ms 3416 KB answer = YES
39 Correct 2 ms 3472 KB answer = YES
40 Correct 2 ms 3416 KB answer = YES
41 Correct 2 ms 3416 KB answer = NO
42 Correct 3 ms 3420 KB answer = YES
43 Correct 3 ms 3420 KB answer = YES
44 Correct 3 ms 3420 KB answer = YES
45 Correct 3 ms 3420 KB answer = YES
46 Correct 2 ms 3420 KB answer = YES
47 Correct 2 ms 3420 KB answer = YES
48 Correct 3 ms 3416 KB answer = YES
# Verdict Execution time Memory Grader output
1 Correct 1 ms 3416 KB answer = YES
2 Correct 2 ms 3420 KB answer = YES
3 Correct 1 ms 3372 KB answer = YES
4 Correct 1 ms 3420 KB answer = NO
5 Correct 2 ms 3420 KB answer = YES
6 Correct 2 ms 3420 KB answer = YES
7 Correct 1 ms 3420 KB answer = YES
8 Correct 2 ms 3420 KB answer = YES
9 Correct 1 ms 3420 KB answer = NO
10 Correct 1 ms 3420 KB answer = YES
11 Correct 2 ms 3420 KB answer = YES
12 Correct 1 ms 3420 KB answer = NO
13 Correct 1 ms 3420 KB answer = YES
14 Correct 1 ms 3420 KB answer = YES
15 Correct 1 ms 3420 KB answer = YES
16 Correct 1 ms 3420 KB answer = YES
17 Correct 1 ms 3420 KB answer = YES
18 Correct 1 ms 3420 KB answer = YES
19 Correct 1 ms 3420 KB answer = YES
20 Correct 1 ms 3420 KB answer = YES
21 Correct 1 ms 3416 KB answer = YES
22 Correct 1 ms 3420 KB answer = NO
23 Correct 1 ms 3420 KB answer = NO
24 Correct 1 ms 3416 KB answer = YES
25 Correct 1 ms 3416 KB answer = YES
26 Correct 2 ms 3420 KB answer = YES
27 Correct 1 ms 3420 KB answer = YES
28 Correct 1 ms 3420 KB answer = YES
29 Correct 1 ms 3416 KB answer = YES
30 Correct 1 ms 3420 KB answer = NO
31 Correct 1 ms 3420 KB answer = YES
32 Correct 1 ms 3420 KB answer = YES
33 Correct 1 ms 3420 KB answer = YES
34 Correct 1 ms 3420 KB answer = YES
35 Correct 1 ms 3420 KB answer = YES
36 Correct 1 ms 3420 KB answer = YES
37 Correct 2 ms 3420 KB answer = YES
38 Correct 1 ms 3416 KB answer = YES
39 Correct 2 ms 3472 KB answer = YES
40 Correct 2 ms 3416 KB answer = YES
41 Correct 2 ms 3416 KB answer = NO
42 Correct 3 ms 3420 KB answer = YES
43 Correct 3 ms 3420 KB answer = YES
44 Correct 3 ms 3420 KB answer = YES
45 Correct 3 ms 3420 KB answer = YES
46 Correct 2 ms 3420 KB answer = YES
47 Correct 2 ms 3420 KB answer = YES
48 Correct 3 ms 3416 KB answer = YES
49 Correct 42 ms 3928 KB answer = YES
50 Correct 10 ms 4188 KB answer = YES
51 Correct 30 ms 4188 KB answer = YES
52 Correct 6 ms 4184 KB answer = NO
53 Correct 3 ms 3420 KB answer = YES
54 Correct 7 ms 3560 KB answer = YES
55 Correct 18 ms 3676 KB answer = YES
56 Correct 41 ms 3928 KB answer = YES
57 Correct 32 ms 3928 KB answer = YES
58 Correct 27 ms 3672 KB answer = YES
59 Correct 14 ms 3932 KB answer = YES
60 Correct 37 ms 3940 KB answer = YES
61 Correct 10 ms 3676 KB answer = YES
62 Correct 41 ms 8532 KB answer = NO
63 Correct 42 ms 8688 KB answer = YES
64 Correct 40 ms 8528 KB answer = NO
65 Correct 44 ms 8536 KB answer = YES
66 Correct 6 ms 3420 KB answer = YES
# Verdict Execution time Memory Grader output
1 Correct 1 ms 3416 KB answer = YES
2 Correct 2 ms 3420 KB answer = YES
3 Correct 1 ms 3372 KB answer = YES
4 Correct 1 ms 3420 KB answer = NO
5 Correct 2 ms 3420 KB answer = YES
6 Correct 2 ms 3420 KB answer = YES
7 Correct 1 ms 3420 KB answer = YES
8 Correct 2 ms 3420 KB answer = YES
9 Correct 1 ms 3420 KB answer = NO
10 Correct 1 ms 3420 KB answer = YES
11 Correct 2 ms 3420 KB answer = YES
12 Correct 1 ms 3420 KB answer = NO
13 Correct 1 ms 3420 KB answer = YES
14 Correct 1 ms 3420 KB answer = YES
15 Correct 1 ms 3420 KB answer = YES
16 Correct 1 ms 3420 KB answer = YES
17 Correct 1 ms 3420 KB answer = YES
18 Correct 1 ms 3420 KB answer = YES
19 Correct 1 ms 3420 KB answer = YES
20 Correct 1 ms 3420 KB answer = YES
21 Correct 1 ms 3416 KB answer = YES
22 Correct 1 ms 3420 KB answer = NO
23 Correct 1 ms 3420 KB answer = NO
24 Correct 1 ms 3416 KB answer = YES
25 Correct 1 ms 3416 KB answer = YES
26 Correct 2 ms 3420 KB answer = YES
27 Correct 1 ms 3420 KB answer = YES
28 Correct 1 ms 3420 KB answer = YES
29 Correct 1 ms 3416 KB answer = YES
30 Correct 1 ms 3420 KB answer = NO
31 Correct 1 ms 3420 KB answer = YES
32 Correct 1 ms 3420 KB answer = YES
33 Correct 1 ms 3420 KB answer = YES
34 Correct 1 ms 3420 KB answer = YES
35 Correct 1 ms 3420 KB answer = YES
36 Correct 1 ms 3420 KB answer = YES
37 Correct 2 ms 3420 KB answer = YES
38 Correct 1 ms 3416 KB answer = YES
39 Correct 2 ms 3472 KB answer = YES
40 Correct 2 ms 3416 KB answer = YES
41 Correct 2 ms 3416 KB answer = NO
42 Correct 3 ms 3420 KB answer = YES
43 Correct 3 ms 3420 KB answer = YES
44 Correct 3 ms 3420 KB answer = YES
45 Correct 3 ms 3420 KB answer = YES
46 Correct 2 ms 3420 KB answer = YES
47 Correct 2 ms 3420 KB answer = YES
48 Correct 3 ms 3416 KB answer = YES
49 Correct 42 ms 3928 KB answer = YES
50 Correct 10 ms 4188 KB answer = YES
51 Correct 30 ms 4188 KB answer = YES
52 Correct 6 ms 4184 KB answer = NO
53 Correct 3 ms 3420 KB answer = YES
54 Correct 7 ms 3560 KB answer = YES
55 Correct 18 ms 3676 KB answer = YES
56 Correct 41 ms 3928 KB answer = YES
57 Correct 32 ms 3928 KB answer = YES
58 Correct 27 ms 3672 KB answer = YES
59 Correct 14 ms 3932 KB answer = YES
60 Correct 37 ms 3940 KB answer = YES
61 Correct 10 ms 3676 KB answer = YES
62 Correct 41 ms 8532 KB answer = NO
63 Correct 42 ms 8688 KB answer = YES
64 Correct 40 ms 8528 KB answer = NO
65 Correct 44 ms 8536 KB answer = YES
66 Correct 6 ms 3420 KB answer = YES
67 Correct 246 ms 13892 KB answer = YES
68 Correct 247 ms 13976 KB answer = YES
69 Correct 183 ms 13776 KB answer = YES
70 Correct 109 ms 17100 KB answer = YES
71 Correct 189 ms 13892 KB answer = YES
72 Correct 530 ms 8252 KB answer = YES
73 Correct 363 ms 8136 KB answer = YES
74 Correct 150 ms 9468 KB answer = YES
75 Correct 139 ms 9420 KB answer = NO
76 Correct 57 ms 3928 KB answer = YES
77 Correct 124 ms 4720 KB answer = YES
78 Correct 211 ms 5660 KB answer = YES
79 Correct 431 ms 7384 KB answer = YES
80 Correct 269 ms 9432 KB answer = YES
81 Correct 103 ms 10896 KB answer = NO
82 Correct 302 ms 13460 KB answer = YES
83 Correct 594 ms 13896 KB answer = YES
84 Incorrect 645 ms 13772 KB participant answer is larger than the answer of jury
85 Halted 0 ms 0 KB -