Submission #38106

# Submission time Handle Problem Language Result Execution time Memory
38106 2018-01-01T07:07:09 Z nibnalin Ferries (NOI13_ferries) C++14
17 / 40
569 ms 26996 KB
#include <iostream>
#include <cstdio>
#include <vector>
#include <set>
using namespace std;

const int maxn = int(1e5)+5, inf = int(2e9)+5;

int D[maxn];
multiset<int> into[maxn];
vector<int> graph[maxn];

int main(void)
{
	int n, m, a, b, c;
	scanf("%d%d", &n, &m);
	for(int i = 0;i < n;i++) D[i] = inf;
	for(int i = 0;i < m;i++)
	{
		scanf("%d%d%d", &a, &b, &c);
		a--, b--;
		graph[b].push_back(a);
		into[a].insert(c);
	}

	set<pair<int, int>> Q;
	D[n-1] = 0;
	Q.insert({D[n-1], n-1});

	while(!Q.empty())
	{
		pair<int, int> top = *Q.begin();
		Q.erase(Q.begin());
		//cout << top.first << " " << top.second << "\n";

		for(auto it: graph[top.second])
		{
			if(into[it].empty()) continue;
			int w = *into[it].rbegin();
			into[it].erase(into[it].find(w));
			if(D[it] > D[top.second]+w)
			{
				D[it] = D[top.second]+w;
				if(D[it] != inf) Q.erase({D[it], it});
				Q.insert({D[it], it});
			}
		}
	}
	printf("%d\n", D[0]);
}

Compilation message

ferries.cpp: In function 'int main()':
ferries.cpp:16:23: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d%d", &n, &m);
                       ^
ferries.cpp:20:30: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d%d%d", &a, &b, &c);
                              ^
# Verdict Execution time Memory Grader output
1 Correct 6 ms 9440 KB Output is correct
2 Correct 0 ms 9572 KB Output is correct
3 Correct 23 ms 10768 KB Output is correct
4 Correct 369 ms 22504 KB Output is correct
5 Correct 419 ms 22504 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 0 ms 9440 KB Output is correct
2 Correct 3 ms 9572 KB Output is correct
3 Correct 16 ms 10632 KB Output is correct
4 Correct 136 ms 15904 KB Output is correct
5 Correct 213 ms 17944 KB Output is correct
# Verdict Execution time Memory Grader output
1 Incorrect 26 ms 11156 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 569 ms 26996 KB Output isn't correct
2 Halted 0 ms 0 KB -