Submission #876624

#TimeUsernameProblemLanguageResultExecution timeMemory
876624n3rm1nSprinkler (JOI22_sprinkler)C++17
12 / 100
600 ms120916 KiB
#include<bits/stdc++.h> #define endl '\n' using namespace std; const int MAXN = 4e5 + 10; void speed() { ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); } int n, mod; vector < int > g[MAXN]; int h[MAXN]; void read() { cin >> n >> mod; int xx, yy; for (int i = 1; i < n; ++ i) { cin >> xx >> yy; g[xx].push_back(yy); g[yy].push_back(xx); } for (int i = 1; i <= n; ++ i) cin >> h[i]; } ///int tin[MAXN], tout[MAXN]; int used[MAXN]; int p[MAXN]; vector < int > on_lvls[MAXN]; int timerr = 0; void dfs(int beg, int parent, int depth) { /// tin[beg] = timerr; p[beg] = parent; used[beg] = 1; ///on_lvls[depth].push_back(beg); int nb, children = 0; for (int i = 0; i < g[beg].size(); ++ i) { nb = g[beg][i]; if(!used[nb]) { children ++; dfs(nb, beg, depth + 1); } } /**if(children) { timerr ++; tout[beg] = timerr; }*/ } int x, d, w; int upd[MAXN][88]; void print_upd() { for (int i = 1; i <= n; ++ i) { cout << "upd for vertex " << i << " " << endl; cout << "depth : "; for (int j = 0; j <= 3; ++ j) cout << upd[i][j] << ", "; cout << endl; } } void update_arrays() { /// cout << "***" << endl; int vertex = x, depth = d; while(vertex != 0 && depth >= 0) { upd[vertex][depth] *= w; upd[vertex][depth] %= mod; if(depth) { upd[vertex][depth-1] *= w; upd[vertex][depth-1] %= mod; } ///cout << vertex << " " << depth << " " << upd[vertex][depth] << endl; ///cout << vertex << " " << depth-1 << " " << upd[vertex][depth-1] << endl; vertex = p[vertex]; depth --; } if(vertex == 0) { for (int i = 0; i <= depth; ++ i) { upd[1][i] *= w; upd[1][i] %= mod; } } } void solve_query() { int anc = x, lvl_diff = 0; int ans = h[x]; //cout << "solving for v = " << anc << endl; while(anc && lvl_diff <= 40) { //cout << "anc = " << anc << " " << "mult is " << upd[anc][lvl_diff] << endl; ans = ans * upd[anc][lvl_diff]; ans %= mod; anc = p[anc]; lvl_diff ++; } cout << ans << endl; } void queries() { int q; cin >> q; int type; while(q --) { cin >> type; if(type == 1) { cin >> x >> d >> w; update_arrays(); ///print_upd(); } else { cin >> x; solve_query(); } } } int main() { speed(); read(); for (int i = 1; i <= n; ++ i) for (int j = 0; j <= 80; ++ j) upd[i][j] = 1; dfs(1, 0, 1); queries(); return 0; }

Compilation message (stderr)

sprinkler.cpp: In function 'void dfs(int, int, int)':
sprinkler.cpp:45:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   45 |     for (int i = 0; i < g[beg].size(); ++ i)
      |                     ~~^~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...