【PAT甲级真题】- Shortest Distance (20)

题目来源

Shortest Distance - PTA
Shortest Distance - 牛客

Description

The task is really simple: given N N N exits on a highway which forms a simple cycle, you are supposed to tell the shortest distance between any pair of exits.

Input Specification:

Each input file contains one test case. For each case, the first line contains an integer N N N ( in 3 , 10 5 3,10\^5 3,105 ), followed by N integer distances D 1 , D 2 ⋯ D N D_1,D_2\cdots D_N D1,D2⋯DN, where D i D_i Di is the distance between the i i i-th and the ( i + 1 ) (i+1) (i+1)-st exits, and D N D_N DN is between the N N N-th and the 1st exits. All the numbers in a line are separated by a space. The second line gives a positive integer M ( ≤ 10 4 ) M(≤10^4) M(≤104), with M M M lines follow, each contains a pair of exit numbers, provided that the exits are numbered from 1 1 1 to N N N. It is guaranteed that the total round trip distance is no more than 10 7 10^7 107

.

Output Specification:

For each test case, print your results in M M M lines, each contains the shortest distance between the corresponding given pair of exits.

Sample Input:

复制代码
5 1 2 4 14 9
3
1 3
2 5
4 1

Sample Output:

复制代码
3
10
7

题目大意

一个有 N N N 个结点的环,给定每个相邻结点之间的距离、

输入若干组 a , b a,b a,b ,问结点 a , b a,b a,b 的最短距离

思路简介

前缀和

用前缀和数组 sum 维护距离, a → b a\to b a→b 的距离就是 s u m b − s u m a sumb-suma sumb−suma

len 表示环的总长度,则 b → a b\to a b→a 的距离就是 l e n − ( s u m b − s n u m a ) len-(sum\[b-snuma) len−(sum\[b−snum[a)

取最小值即可

遇到的问题

  1. 无,一遍过

代码

cpp 复制代码
/**
 * Shortest Distance
 * https://pintia.cn/problem-sets/994805342720868352/exam/problems/type/7?problemSetProblemId=994805435700199424
 * https://www.nowcoder.com/pat/5/problem/4085
 * 前缀和
 */
#include<bits/stdc++.h>
using namespace std;

const int N=1e5+10;
int d[N],n;

void init(){
    d[1]=0;
    cin>>n;
    for(int i=1;i<=n;++i){
        int tmp;cin>>tmp;
        d[i+1]=d[i]+tmp;
    }
}

void solve(){
    int i,j;
    cin>>i>>j;
    int len=d[n+1];
    int res=abs(d[j]-d[i]);
    cout<<min(res,len-res)<<'\n';
}   

int main(){
    ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
    //fstream in("in.txt",ios::in);cin.rdbuf(in.rdbuf());
    int T=1;
    init();
    cin>>T;
    while(T--){
        solve();
    }
    return 0;
}
相关推荐
8Qi82 小时前
LeetCode 494:目标和(Target Sum)—— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
hujinyuan201602 小时前
2026年3月 中国电子学会青少年软件编程(Python)三级考试试卷 真题及答案
java·python·算法
froyoisle3 小时前
CSP-J 历年复赛 T1 及解析(2019~2025)
数据结构·c++·算法·csp-j·csp·算法竞赛·信息学
basketball6163 小时前
C++ 高级编程:2. 基本线程池实现
java·开发语言·c++
珊瑚里的鱼3 小时前
【动态规划】打家劫舍Ⅱ
算法·动态规划
chao1898443 小时前
SGM(Semi-Global Matching)立体匹配算法 — C++ 实现
开发语言·c++·算法
黎阳之光3 小时前
数智赋能水厂全链路安全|黎阳之光以视频孪生技术落地供水精细化管控
人工智能·物联网·算法·安全·数字孪生
10岁的博客3 小时前
IOI 2018 高速公路收费(Highway)题解:二分与树的巧妙结合
开发语言·c++
不知名的老吴3 小时前
C++运算符重载的常见注意点
开发语言·c++
喜欢打篮球的普通人3 小时前
LLVM 后端流程与关键数据结构:从 IR 到机器码的入门笔记
java·数据结构·笔记