Submission #423845

# Submission time Handle Problem Language Result Execution time Memory
423845 2021-06-11T13:15:03 Z vanic Shortcut (IOI16_shortcut) C++14
0 / 100
1 ms 256 KB
#include "shortcut.h"
#include <algorithm>
#include <cmath>
#include <vector>
#include <bitset>
#include <queue>
#include <set>
#include <iostream>

using namespace std;

typedef long long ll;

const int maxn=505;

vector < pair < int, int > > ms[maxn];
bitset < maxn > bio;
int n;
int br;

ll kreni(int x){
	set < pair < ll, int > > s;
	s.insert({0, x});
	pair < int, int > p;
	ll zadnj;
	while(!s.empty()){
		p=*s.begin();
		s.erase(s.begin());
//		cout << "a sad je  " << p.second << endl;
		if(bio[p.second]){
//			cout << "cont" << endl;
			continue;
		}
		zadnj=p.first;
		bio[p.second]=1;
		x=p.second;
		for(int i=0; i<(int)ms[x].size(); i++){
			if(!bio[ms[x][i].first]){
//				cout << "sirim " << p.first << ' ' << ms[x][i].second << ' ' << ms[x][i].first  << endl;
				s.insert({p.first+ms[x][i].second, ms[x][i].first});
			}
		}
	}
//	cout << x << ' ' << zadnj << endl;
	return zadnj;
}

ll rijesi(){
	ll sol=0;
	for(int i=0; i<br; i++){
		sol=max(sol, kreni(i));
		bio.reset();
	}
	return sol;
}

ll find_shortcut(int nn, vector < int > l, vector < int > d, int c){
	n=nn;
	for(int i=0; i<n-1; i++){
		ms[i].push_back({i+1, l[i]});
		ms[i+1].push_back({i, l[i]});
	}
	br=n;
	for(int i=0; i<n; i++){
		if(d[i]){
			ms[br].push_back({i, d[i]});
			ms[i].push_back({br, d[i]});
			br++;
		}
	}
	ll sol=1e18;
	for(int i=0; i<n; i++){
		for(int j=i+1; j<n; j++){
			ms[i].push_back({j, c});
			ms[j].push_back({i, c});
			sol=min(sol, rijesi());
			ms[i].pop_back();
			ms[j].pop_back();
		}
	}
	return sol;
}

Compilation message

shortcut.cpp: In function 'll kreni(int)':
shortcut.cpp:45:9: warning: 'zadnj' may be used uninitialized in this function [-Wmaybe-uninitialized]
   45 |  return zadnj;
      |         ^~~~~
# Verdict Execution time Memory Grader output
1 Correct 1 ms 204 KB n = 4, 80 is a correct answer
2 Correct 1 ms 204 KB n = 9, 110 is a correct answer
3 Correct 1 ms 204 KB n = 4, 21 is a correct answer
4 Correct 1 ms 204 KB n = 3, 4 is a correct answer
5 Correct 1 ms 256 KB n = 2, 62 is a correct answer
6 Correct 0 ms 204 KB n = 2, 3 is a correct answer
7 Correct 1 ms 204 KB n = 3, 29 is a correct answer
8 Correct 1 ms 204 KB n = 2, 3 is a correct answer
9 Correct 1 ms 204 KB n = 2, 3 is a correct answer
10 Correct 0 ms 204 KB n = 2, 2000000001 is a correct answer
11 Incorrect 1 ms 204 KB n = 2, incorrect answer: jury 3000000000 vs contestant 2000000000
12 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 1 ms 204 KB n = 4, 80 is a correct answer
2 Correct 1 ms 204 KB n = 9, 110 is a correct answer
3 Correct 1 ms 204 KB n = 4, 21 is a correct answer
4 Correct 1 ms 204 KB n = 3, 4 is a correct answer
5 Correct 1 ms 256 KB n = 2, 62 is a correct answer
6 Correct 0 ms 204 KB n = 2, 3 is a correct answer
7 Correct 1 ms 204 KB n = 3, 29 is a correct answer
8 Correct 1 ms 204 KB n = 2, 3 is a correct answer
9 Correct 1 ms 204 KB n = 2, 3 is a correct answer
10 Correct 0 ms 204 KB n = 2, 2000000001 is a correct answer
11 Incorrect 1 ms 204 KB n = 2, incorrect answer: jury 3000000000 vs contestant 2000000000
12 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 1 ms 204 KB n = 4, 80 is a correct answer
2 Correct 1 ms 204 KB n = 9, 110 is a correct answer
3 Correct 1 ms 204 KB n = 4, 21 is a correct answer
4 Correct 1 ms 204 KB n = 3, 4 is a correct answer
5 Correct 1 ms 256 KB n = 2, 62 is a correct answer
6 Correct 0 ms 204 KB n = 2, 3 is a correct answer
7 Correct 1 ms 204 KB n = 3, 29 is a correct answer
8 Correct 1 ms 204 KB n = 2, 3 is a correct answer
9 Correct 1 ms 204 KB n = 2, 3 is a correct answer
10 Correct 0 ms 204 KB n = 2, 2000000001 is a correct answer
11 Incorrect 1 ms 204 KB n = 2, incorrect answer: jury 3000000000 vs contestant 2000000000
12 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 1 ms 204 KB n = 4, 80 is a correct answer
2 Correct 1 ms 204 KB n = 9, 110 is a correct answer
3 Correct 1 ms 204 KB n = 4, 21 is a correct answer
4 Correct 1 ms 204 KB n = 3, 4 is a correct answer
5 Correct 1 ms 256 KB n = 2, 62 is a correct answer
6 Correct 0 ms 204 KB n = 2, 3 is a correct answer
7 Correct 1 ms 204 KB n = 3, 29 is a correct answer
8 Correct 1 ms 204 KB n = 2, 3 is a correct answer
9 Correct 1 ms 204 KB n = 2, 3 is a correct answer
10 Correct 0 ms 204 KB n = 2, 2000000001 is a correct answer
11 Incorrect 1 ms 204 KB n = 2, incorrect answer: jury 3000000000 vs contestant 2000000000
12 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 1 ms 204 KB n = 4, 80 is a correct answer
2 Correct 1 ms 204 KB n = 9, 110 is a correct answer
3 Correct 1 ms 204 KB n = 4, 21 is a correct answer
4 Correct 1 ms 204 KB n = 3, 4 is a correct answer
5 Correct 1 ms 256 KB n = 2, 62 is a correct answer
6 Correct 0 ms 204 KB n = 2, 3 is a correct answer
7 Correct 1 ms 204 KB n = 3, 29 is a correct answer
8 Correct 1 ms 204 KB n = 2, 3 is a correct answer
9 Correct 1 ms 204 KB n = 2, 3 is a correct answer
10 Correct 0 ms 204 KB n = 2, 2000000001 is a correct answer
11 Incorrect 1 ms 204 KB n = 2, incorrect answer: jury 3000000000 vs contestant 2000000000
12 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 1 ms 204 KB n = 4, 80 is a correct answer
2 Correct 1 ms 204 KB n = 9, 110 is a correct answer
3 Correct 1 ms 204 KB n = 4, 21 is a correct answer
4 Correct 1 ms 204 KB n = 3, 4 is a correct answer
5 Correct 1 ms 256 KB n = 2, 62 is a correct answer
6 Correct 0 ms 204 KB n = 2, 3 is a correct answer
7 Correct 1 ms 204 KB n = 3, 29 is a correct answer
8 Correct 1 ms 204 KB n = 2, 3 is a correct answer
9 Correct 1 ms 204 KB n = 2, 3 is a correct answer
10 Correct 0 ms 204 KB n = 2, 2000000001 is a correct answer
11 Incorrect 1 ms 204 KB n = 2, incorrect answer: jury 3000000000 vs contestant 2000000000
12 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 1 ms 204 KB n = 4, 80 is a correct answer
2 Correct 1 ms 204 KB n = 9, 110 is a correct answer
3 Correct 1 ms 204 KB n = 4, 21 is a correct answer
4 Correct 1 ms 204 KB n = 3, 4 is a correct answer
5 Correct 1 ms 256 KB n = 2, 62 is a correct answer
6 Correct 0 ms 204 KB n = 2, 3 is a correct answer
7 Correct 1 ms 204 KB n = 3, 29 is a correct answer
8 Correct 1 ms 204 KB n = 2, 3 is a correct answer
9 Correct 1 ms 204 KB n = 2, 3 is a correct answer
10 Correct 0 ms 204 KB n = 2, 2000000001 is a correct answer
11 Incorrect 1 ms 204 KB n = 2, incorrect answer: jury 3000000000 vs contestant 2000000000
12 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 1 ms 204 KB n = 4, 80 is a correct answer
2 Correct 1 ms 204 KB n = 9, 110 is a correct answer
3 Correct 1 ms 204 KB n = 4, 21 is a correct answer
4 Correct 1 ms 204 KB n = 3, 4 is a correct answer
5 Correct 1 ms 256 KB n = 2, 62 is a correct answer
6 Correct 0 ms 204 KB n = 2, 3 is a correct answer
7 Correct 1 ms 204 KB n = 3, 29 is a correct answer
8 Correct 1 ms 204 KB n = 2, 3 is a correct answer
9 Correct 1 ms 204 KB n = 2, 3 is a correct answer
10 Correct 0 ms 204 KB n = 2, 2000000001 is a correct answer
11 Incorrect 1 ms 204 KB n = 2, incorrect answer: jury 3000000000 vs contestant 2000000000
12 Halted 0 ms 0 KB -