제출 #267095

#제출 시각아이디문제언어결과실행 시간메모리
267095kimbj0709다리 (APIO19_bridges)C++14
14 / 100
118 ms13160 KiB
#include<bits/stdc++.h> using namespace std; #define int long long #define maxn 100050 #define f first #define s second vector<int> ufds(maxn); vector<int> s(maxn,1); int find(int k){ if(ufds[k]!=k){ ufds[k] = find(ufds[k]); } return ufds[k]; } void merge(int a,int b){ int temp1 = find(a); int temp2 = find(b); if(temp1==temp2){ return; } ufds[temp1] = temp2; s[temp2] += s[temp1]; } int32_t main(){ ios::sync_with_stdio(0); cin.tie(0);cout.tie(0); int n,m,q; for(int i=0;i<ufds.size();i++){ ufds[i] = i; } int input1,input2,input3; vector<pair<int,pair<int,int> > > edges; cin >> n >> m; for(int i=0;i<m;i++){ cin >> input1 >> input2 >> input3; edges.push_back({input3,{input1,input2}}); } sort(edges.begin(),edges.end()); vector<pair<int,pair<int,int> > > queries; cin >> q; vector<int> ans(maxn); for(int i=0;i<q;i++){ cin >> input1 >> input3 >> input2; queries.push_back({input2,{input3,i}}); } sort(queries.begin(),queries.end()); reverse(queries.begin(),queries.end()); reverse(edges.begin(),edges.end()); int currpos = 0; for(int i=0;i<queries.size();i++){ while(currpos<edges.size()&&edges[currpos].f>=queries[i].f){ merge(edges[currpos].s.f,edges[currpos].s.s); currpos++; } /*for(int j=1;j<=n;j++){ cout << s[j] << ' '; } cout << endl; cout << find(queries[i].s.f) << "--\n";*/ ans[queries[i].s.s] = s[find(queries[i].s.f)]; } for(int i=0;i<q;i++){ cout << ans[i] << "\n"; } }

컴파일 시 표준 에러 (stderr) 메시지

bridges.cpp: In function 'int32_t main()':
bridges.cpp:28:18: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   28 |     for(int i=0;i<ufds.size();i++){
      |                 ~^~~~~~~~~~~~
bridges.cpp:50:18: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::pair<long long int, std::pair<long long int, long long int> > >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   50 |     for(int i=0;i<queries.size();i++){
      |                 ~^~~~~~~~~~~~~~~
bridges.cpp:51:22: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::pair<long long int, std::pair<long long int, long long int> > >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   51 |         while(currpos<edges.size()&&edges[currpos].f>=queries[i].f){
      |               ~~~~~~~^~~~~~~~~~~~~
#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...