Submission #937112

#TimeUsernameProblemLanguageResultExecution timeMemory
9371121075508020060209tcCities (BOI16_cities)C++14
Compilation error
0 ms0 KiB
#include<bits/stdc++.h> //#include<bits/extc++.h> using namespace std; //using namespace __gnu_pbds; #define int long long int n;int K;int m; int imp[8]; vector<pair<int,int>>e[100005]; void dijkstera(vector<int>ost,vector<int>&dis){ priority_queue<pair<int,int>,vector<pair<int,int>>,greater<pair<int,int>>>pq; for(int i:ost){ pq.push({dis[i],i}); } bitset<100005>vis; while(pq.size()){ int nw=pq.top().second; pq.pop(); if(vis[nw]){continue;} vis[nw]=1; for(auto pr:e[nw]){ int v=pr.first; int w=pr.second; if(vis[v]){continue;} if(dis[v]>dis[nw]+w){ dis[v]=dis[nw]+w; pq.push({dis[v],v}); } } } } vector<int>disa[6]; vector<int>disab[6][6]; void init(){ cin>>n>>K>>m; for(int i=1;i<=K;i++){ cin>>imp[i]; disa[i].resize(n+10,0); } for(int i=1;i<=m;i++){ int a;int b;int c; cin>>a>>b>>c; e[a].push_back({b,c}); e[b].push_back({a,c}); } } signed main(){ init(); for(int i=1;i<=K;i++){ for(int j=1;j<=n;j++){ disa[i][j]=1e16; } disa[i][imp[i]]=0; vector<int>vc={imp[i]}; dijkstera(vc,disa[i]); } if(K==2){ cout<<disa[1][imp[2]];return 0; } for(int i=1;i<=K;i++){ for(int j=i+1;j<=K;j++){ //if(i==j){continue;} disab[i][j].resize(n+10); vector<int>vc; for(int v=1;v<=n;v++){ disab[i][j][v]=disa[i][v]+disa[j][v]; vc.push_back(v); } dijkstera(vc,disab[i][j]); } } int ans=1e18; if(n==4){ vector<vector<int>>dis2(n+2,vector<int>(n+2,1e18)); for(int a=1;a<=n;a++){ dis2[a][a]=0; dijkstera({a},dis2[a]); } for(int a=1;a<=n;a++){ ans=min(ans,disa[1][a]+disa[2][a]+disa[3][a]+disa[4][a]); for(int b=1;b<=n;b++){ ans=min(ans,dis2[a][b]+min(dis2[a][imp[1]],dis2[b][imp[1]])+min(dis2[a][imp[2]],dis2[b][imp[2]]),min(dis2[a][imp[3]],dis2[b][imp[3]]),min(dis2[a][imp[4]],dis2[b][imp[4]]) ); } } cout<<ans;return 0; } ans=disab[1][2][imp[3]]; cout<<ans<<endl; }

Compilation message (stderr)

cities.cpp: In function 'int main()':
cities.cpp:90:185: error: no matching function for call to 'min(long long int&, __gnu_cxx::__alloc_traits<std::allocator<long long int>, long long int>::value_type, const long long int&, const long long int&)'
   90 |             ans=min(ans,dis2[a][b]+min(dis2[a][imp[1]],dis2[b][imp[1]])+min(dis2[a][imp[2]],dis2[b][imp[2]]),min(dis2[a][imp[3]],dis2[b][imp[3]]),min(dis2[a][imp[4]],dis2[b][imp[4]])  );
      |                                                                                                                                                                                         ^
In file included from /usr/include/c++/10/bits/char_traits.h:39,
                 from /usr/include/c++/10/ios:40,
                 from /usr/include/c++/10/istream:38,
                 from /usr/include/c++/10/sstream:38,
                 from /usr/include/c++/10/complex:45,
                 from /usr/include/c++/10/ccomplex:39,
                 from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54,
                 from cities.cpp:1:
/usr/include/c++/10/bits/stl_algobase.h:230:5: note: candidate: 'template<class _Tp> constexpr const _Tp& std::min(const _Tp&, const _Tp&)'
  230 |     min(const _Tp& __a, const _Tp& __b)
      |     ^~~
/usr/include/c++/10/bits/stl_algobase.h:230:5: note:   template argument deduction/substitution failed:
cities.cpp:90:185: note:   candidate expects 2 arguments, 4 provided
   90 |             ans=min(ans,dis2[a][b]+min(dis2[a][imp[1]],dis2[b][imp[1]])+min(dis2[a][imp[2]],dis2[b][imp[2]]),min(dis2[a][imp[3]],dis2[b][imp[3]]),min(dis2[a][imp[4]],dis2[b][imp[4]])  );
      |                                                                                                                                                                                         ^
In file included from /usr/include/c++/10/bits/char_traits.h:39,
                 from /usr/include/c++/10/ios:40,
                 from /usr/include/c++/10/istream:38,
                 from /usr/include/c++/10/sstream:38,
                 from /usr/include/c++/10/complex:45,
                 from /usr/include/c++/10/ccomplex:39,
                 from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54,
                 from cities.cpp:1:
/usr/include/c++/10/bits/stl_algobase.h:278:5: note: candidate: 'template<class _Tp, class _Compare> constexpr const _Tp& std::min(const _Tp&, const _Tp&, _Compare)'
  278 |     min(const _Tp& __a, const _Tp& __b, _Compare __comp)
      |     ^~~
/usr/include/c++/10/bits/stl_algobase.h:278:5: note:   template argument deduction/substitution failed:
cities.cpp:90:185: note:   candidate expects 3 arguments, 4 provided
   90 |             ans=min(ans,dis2[a][b]+min(dis2[a][imp[1]],dis2[b][imp[1]])+min(dis2[a][imp[2]],dis2[b][imp[2]]),min(dis2[a][imp[3]],dis2[b][imp[3]]),min(dis2[a][imp[4]],dis2[b][imp[4]])  );
      |                                                                                                                                                                                         ^
In file included from /usr/include/c++/10/algorithm:62,
                 from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:65,
                 from cities.cpp:1:
/usr/include/c++/10/bits/stl_algo.h:3468:5: note: candidate: 'template<class _Tp> constexpr _Tp std::min(std::initializer_list<_Tp>)'
 3468 |     min(initializer_list<_Tp> __l)
      |     ^~~
/usr/include/c++/10/bits/stl_algo.h:3468:5: note:   template argument deduction/substitution failed:
cities.cpp:90:185: note:   mismatched types 'std::initializer_list<_Tp>' and 'long long int'
   90 |             ans=min(ans,dis2[a][b]+min(dis2[a][imp[1]],dis2[b][imp[1]])+min(dis2[a][imp[2]],dis2[b][imp[2]]),min(dis2[a][imp[3]],dis2[b][imp[3]]),min(dis2[a][imp[4]],dis2[b][imp[4]])  );
      |                                                                                                                                                                                         ^
In file included from /usr/include/c++/10/algorithm:62,
                 from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:65,
                 from cities.cpp:1:
/usr/include/c++/10/bits/stl_algo.h:3474:5: note: candidate: 'template<class _Tp, class _Compare> constexpr _Tp std::min(std::initializer_list<_Tp>, _Compare)'
 3474 |     min(initializer_list<_Tp> __l, _Compare __comp)
      |     ^~~
/usr/include/c++/10/bits/stl_algo.h:3474:5: note:   template argument deduction/substitution failed:
cities.cpp:90:185: note:   mismatched types 'std::initializer_list<_Tp>' and 'long long int'
   90 |             ans=min(ans,dis2[a][b]+min(dis2[a][imp[1]],dis2[b][imp[1]])+min(dis2[a][imp[2]],dis2[b][imp[2]]),min(dis2[a][imp[3]],dis2[b][imp[3]]),min(dis2[a][imp[4]],dis2[b][imp[4]])  );
      |                                                                                                                                                                                         ^