結果
問題 | No.1216 灯籠流し/Lanterns |
ユーザー | kaage |
提出日時 | 2020-08-01 17:02:32 |
言語 | C++14 (gcc 12.3.0 + boost 1.83.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 3,384 bytes |
コンパイル時間 | 1,120 ms |
コンパイル使用メモリ | 127,712 KB |
実行使用メモリ | 19,072 KB |
最終ジャッジ日時 | 2024-07-18 11:59:07 |
合計ジャッジ時間 | 9,120 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 3 ms
19,072 KB |
testcase_01 | AC | 3 ms
6,144 KB |
testcase_02 | AC | 3 ms
6,144 KB |
testcase_03 | AC | 3 ms
6,144 KB |
testcase_04 | AC | 27 ms
9,856 KB |
testcase_05 | TLE | - |
testcase_06 | -- | - |
testcase_07 | -- | - |
testcase_08 | -- | - |
testcase_09 | -- | - |
testcase_10 | -- | - |
testcase_11 | -- | - |
testcase_12 | -- | - |
testcase_13 | -- | - |
testcase_14 | -- | - |
testcase_15 | -- | - |
testcase_16 | -- | - |
testcase_17 | -- | - |
testcase_18 | -- | - |
testcase_19 | -- | - |
testcase_20 | -- | - |
testcase_21 | -- | - |
testcase_22 | -- | - |
testcase_23 | -- | - |
testcase_24 | -- | - |
testcase_25 | -- | - |
testcase_26 | -- | - |
testcase_27 | -- | - |
testcase_28 | -- | - |
testcase_29 | -- | - |
testcase_30 | -- | - |
testcase_31 | -- | - |
testcase_32 | -- | - |
testcase_33 | -- | - |
testcase_34 | -- | - |
testcase_35 | -- | - |
testcase_36 | -- | - |
testcase_37 | -- | - |
testcase_38 | -- | - |
testcase_39 | -- | - |
testcase_40 | -- | - |
testcase_41 | -- | - |
testcase_42 | -- | - |
testcase_43 | -- | - |
testcase_44 | -- | - |
testcase_45 | -- | - |
testcase_46 | -- | - |
testcase_47 | -- | - |
testcase_48 | -- | - |
testcase_49 | -- | - |
ソースコード
#line 2 "/Users/kaage/Desktop/ProgrammingWorkspace/library/other/template.hpp" #define _CRT_SECURE_NO_WARNINGS #pragma target("avx") #pragma optimize("O3") #pragma optimize("unroll-loops") #include <algorithm> #include <bitset> #include <cassert> #include <cfloat> #include <climits> #include <cmath> #include <complex> #include <ctime> #include <deque> #include <fstream> #include <functional> #include <iomanip> #include <iostream> #include <iterator> #include <list> #include <map> #include <memory> #include <queue> #include <random> #include <set> #include <stack> #include <string> #include <string.h> #include <unordered_map> #include <unordered_set> #include <utility> #include <vector> #define rep(i,n) for(int i=0;i<(lint)(n);i++) #define REP(i,n) for(int i=1;i<=(lint)(n);i++) #define all(V) V.begin(),V.end() typedef long long lint; typedef unsigned long long ulint; typedef std::pair<int, int> P; typedef std::pair<lint, lint> LP; constexpr int INF = INT_MAX/2; constexpr lint LINF = LLONG_MAX/2; constexpr double eps = DBL_EPSILON; constexpr double PI=3.141592653589793238462643383279; template<class T> class prique :public std::priority_queue<T, std::vector<T>, std::greater<T>> {}; template <class T, class U> inline bool chmax(T& lhs, const U& rhs) { if (lhs < rhs) { lhs = rhs; return 1; } return 0; } template <class T, class U> inline bool chmin(T& lhs, const U& rhs) { if (lhs > rhs) { lhs = rhs; return 1; } return 0; } inline lint gcd(lint a, lint b) { while (b) { lint c = a; a = b; b = c % b; } return a; } inline lint lcm(lint a, lint b) { return a / gcd(a, b) * b; } bool isprime(lint n) { if (n == 1)return false; for (int i = 2; i * i <= n; i++) { if (n % i == 0)return false; } return true; } template<typename T> T mypow(T a, lint b) { if (!b)return T(1); if (b & 1)return mypow(a, b - 1) * a; T memo = mypow(a, b >> 1); return memo * memo; } lint modpow(lint a, lint b, lint m) { if (!b)return 1; if (b & 1)return modpow(a, b - 1, m) * a % m; lint memo = modpow(a, b >> 1, m); return memo * memo % m; } template<typename T> void printArray(std::vector<T>& vec) { rep(i, vec.size() - 1)std::cout << vec[i] << " "; std::cout << vec.back() << std::endl; } template<typename T> void printArray(T l, T r) { T rprev = r; rprev--; for (T i = l; i != rprev; i++) { std::cout << *i << " "; } std::cout << *rprev << std::endl; } #line 2 "simple.cpp" int N,Q; lint type[100010],v[100010],t[100010],l[100010]; lint ans[100010]; std::vector<LP> vec[50010],children[50010]; LP par[50010]; bool used[50010]; lint dist[50010]; void dfs(int node){ used[node]=true; for(const auto& i:vec[node]){ if(!used[i.first]){ children[node].emplace_back(i); dfs(i.first); } } } int main(){ scanf("%d %d",&N,&Q); rep(i,N-1){ lint a,b,c; scanf("%lld %lld %lld",&a,&b,&c); vec[a].emplace_back(b,c); vec[b].emplace_back(a,c); } rep(i,Q)scanf("%lld %lld %lld %lld",type+i,v+i,t+i,l+i); dfs(1); std::queue<P> que; rep(i,Q){ if(type[i]==1){ std::fill(dist+1,dist+N+1,LINF); que.push({v[i],0}); while(!que.empty()){ P p=que.front(); que.pop(); dist[p.first]=p.second; for(const P& j:children[p.first]){ que.push({j.first,p.second+j.second}); } } int ans=0; rep(j,i){ if(type[j]==0&&t[j]+dist[v[j]]<=t[i]&&dist[v[j]]<=l[j])ans++; } printf("%d\n",ans); } } }