All ICPC entries
Competitive Programming

ICPC 2016 - I. Road Times

State the problem in your own words. Focus on the mathematical or algorithmic core rather than repeating the full statement.

Source sync Apr 19, 2026
Track ICPC
Year 2016
Files TeX, C++, statement assets
Folder competitive_programming/icpc/2016/I-road-times
ICPC2016TeXC++statement textstatement pdf

Source-first archive entry

This page is built from the copied files in competitive_programming/icpc/2016/I-road-times. Edit competitive_programming/icpc/2016/I-road-times/solution.tex to update the written solution and competitive_programming/icpc/2016/I-road-times/solution.cpp to update the implementation.

The website does not replace those files with hand-maintained HTML. It reads the copied source tree during the build and exposes the exact files below.

Problem Statement

Copied statement text kept beside the solution archive for direct reference.

Problem I
                                          Road Times
                                    Time limit: 5 seconds
Ubol Narongdid is the founder of a brash new startup company called Special D-Liver-E. She wants to
corner the market on overnight deliveries of organs between hospitals in the Phuket area. For scheduling
purposes it is important to have accurate estimates for the times to perform such deliveries. Several
trips between various hospitals have already been performed, so delivery times between those pairs of
hospitals are known. The company currently has software to estimate times for other (as yet untraveled)
trips, but so far all the estimates have been woefully inaccurate.
You have been asked to come up with a method to improve these estimates. You have at your disposal
the following information: 1) the length (in kilometers) of the roads connecting each pair of cities in the
Phuket area, and 2) a set of times (in minutes) for various previously executed deliveries.
You know that roads are one-way, and each road has a fixed speed limit that lies between 30 and 60
kilometers per hour. Speed limits are real-valued and need not be integers. You also know that delivery
trucks always take the route that minimizes distance traveled, and on each road will always travel at a
constant speed equal to that road’s speed limit. Thus you know, for example, that if a given trip is 50
kilometers, the time it will take is between 50 and 100 minutes inclusive, in the absence of any other
information. Ah, but you do have other information, namely the times of previous deliveries. It is up to
you to use it to produce the best possible estimates.

Input

The input starts with a line containing an integer n (1 ≤ n ≤ 30) indicating the number of cities,
numbered 0 to n − 1. After that are n lines each containing n integers specifying the distance in
kilometers between cities: the j th value on the ith line indicates the distance when traveling directly
from city i to city j. A value of −1 indicates there is no road directly connecting the two cities, and the
distance from any city to itself is always 0; all other distances are positive and at most 1 000. There are
at most 100 roads.
Following this is a line with a single integer r (1 ≤ r ≤ 100) indicating the number of previously
executed routes. The next r lines each contain three integers s, d, and t, where s and d are the source
and destination cities and t is how long the delivery from s to d took, in minutes.
Finally there is a line containing a single integer q (1 ≤ q ≤ 100) indicating the number of future
delivery queries. The next q lines each contain two integers s and d giving the source and destination
cities for the query.
You may assume that for each of the r+q source/destination pairs in the input there is a unique minimum-
distance route.

Output

Display a single line for each query containing the source and destination cities for that query, followed
by the best low and high bounds on the estimate for the travel time, accurate to within an absolute or
relative error of 10−6 .

Sample Input 1                                Sample Output 1
3                                             0 1 50.0 80.0
0 50 -1                                       1 2 40.0 70.0
55 0 40                                       1 0 55.0 110.0
-1 40 0
1
0 2 120
3
0 1
1 2
1 0

Editorial

Rendered from the copied solution.tex file. The original TeX source remains available below.

Key Observations

  • Write the structural observations that make the problem tractable.

  • State any useful invariant, monotonicity property, graph interpretation, or combinatorial reformulation.

  • If the constraints matter, explain exactly which part of the solution they enable.

Algorithm

  1. Describe the data structures and the state maintained by the algorithm.

  2. Explain the processing order and why it is sufficient.

  3. Mention corner cases explicitly if they affect the implementation.

Correctness Proof

We prove that the algorithm returns the correct answer.

Lemma 1.

State the first key claim.

Proof.

Provide a concise proof.

Lemma 2.

State the next claim if needed.

Proof.

Provide a concise proof.

Theorem.

The algorithm outputs the correct answer for every valid input.

Proof.

Combine the lemmas and finish the argument.

Complexity Analysis

State the running time and memory usage in terms of the input size.

Implementation Notes

  • Mention any non-obvious implementation detail that is easy to get wrong.

  • Mention numeric limits, indexing conventions, or tie-breaking rules if relevant.

Code

Exact copied C++ implementation from solution.cpp.

C++ competitive_programming/icpc/2016/I-road-times/solution.cpp

Exact copied implementation source.

Raw file
#include <bits/stdc++.h>
using namespace std;

namespace {

void solve() {
    // Fill in the full solution logic for the problem here.
}

}  // namespace

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    solve();
    return 0;
}

Source Files

Exact copied source-of-truth files. Edit solution.tex for the write-up and solution.cpp for the implementation.

TeX write-up competitive_programming/icpc/2016/I-road-times/solution.tex

Exact copied write-up source.

Raw file
\documentclass[11pt]{article}
\usepackage[margin=1in]{geometry}
\usepackage[T1]{fontenc}
\usepackage[utf8]{inputenc}
\usepackage{amsmath,amssymb,amsthm}
\usepackage{enumitem}

\title{ICPC World Finals 2016\\I. Road Times}
\author{}
\date{}

\begin{document}
\maketitle

\section*{Problem Summary}

State the problem in your own words. Focus on the mathematical or algorithmic core rather than repeating the full statement.

\section*{Key Observations}

\begin{itemize}[leftmargin=*]
    \item Write the structural observations that make the problem tractable.
    \item State any useful invariant, monotonicity property, graph interpretation, or combinatorial reformulation.
    \item If the constraints matter, explain exactly which part of the solution they enable.
\end{itemize}

\section*{Algorithm}

\begin{enumerate}[leftmargin=*]
    \item Describe the data structures and the state maintained by the algorithm.
    \item Explain the processing order and why it is sufficient.
    \item Mention corner cases explicitly if they affect the implementation.
\end{enumerate}

\section*{Correctness Proof}

We prove that the algorithm returns the correct answer.

\paragraph{Lemma 1.}
State the first key claim.

\paragraph{Proof.}
Provide a concise proof.

\paragraph{Lemma 2.}
State the next claim if needed.

\paragraph{Proof.}
Provide a concise proof.

\paragraph{Theorem.}
The algorithm outputs the correct answer for every valid input.

\paragraph{Proof.}
Combine the lemmas and finish the argument.

\section*{Complexity Analysis}

State the running time and memory usage in terms of the input size.

\section*{Implementation Notes}

\begin{itemize}[leftmargin=*]
    \item Mention any non-obvious implementation detail that is easy to get wrong.
    \item Mention numeric limits, indexing conventions, or tie-breaking rules if relevant.
\end{itemize}

\end{document}