제출 #725073

#제출 시각아이디문제언어결과실행 시간메모리
725073tigarJakarta Skyscrapers (APIO15_skyscraper)C++14
22 / 100
1093 ms262144 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; ll b[50030], p[50030]; vector<ll>srapers[50030]; vector<pair<ll, ll> >graff[50030]; ll dist[50030]; bool check1[50030]; ll INF=LONG_LONG_MAX; void dijkstra(ll cvor) { for(int i=0; i<50030; i++){check1[i]=false; dist[i]=INF;} priority_queue<pair<ll, ll> >ord; dist[cvor]=0; ord.push({0, cvor}); while(!ord.empty()) { int cv=ord.top().second; ord.pop(); if(check1[cv])continue; check1[cv]=true; for(int j=0; j<graff[cv].size(); j++) { ll pp=graff[cv][j].first; dist[pp]=min(dist[pp], dist[cv]+graff[cv][j].second); if(!check1[pp])ord.push({-dist[pp], pp}); } } } int main() { ll m, n; cin>>n>>m; for(int i=0; i<m; i++) { cin>>b[i]>>p[i]; srapers[b[i]].push_back(i); } for(int i=0; i<m; i++) { ll br=0; while(b[i]-br*p[i]>=0 or b[i]+br*p[i]<n) { int j; if(b[i]-br*p[i]>=0) { j=b[i]-br*p[i]; for(int l=0; l<srapers[j].size(); l++) { graff[i].push_back({srapers[j][l], br}); } } if(b[i]+br*p[i]<n) { j=b[i]+br*p[i]; for(int l=0; l<srapers[j].size(); l++) { graff[i].push_back({srapers[j][l], br}); } } br++; } } dijkstra(0); if(dist[1]==INF){cout<<-1; return 0;} cout<<dist[1]; return 0; }

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

skyscraper.cpp: In function 'void dijkstra(ll)':
skyscraper.cpp:24:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   24 |         for(int j=0; j<graff[cv].size(); j++)
      |                      ~^~~~~~~~~~~~~~~~~
skyscraper.cpp: In function 'int main()':
skyscraper.cpp:51:31: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   51 |                 for(int l=0; l<srapers[j].size(); l++)
      |                              ~^~~~~~~~~~~~~~~~~~
skyscraper.cpp:59:31: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   59 |                 for(int l=0; l<srapers[j].size(); l++)
      |                              ~^~~~~~~~~~~~~~~~~~
#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...