国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

1046. Shortest Distance (20)

2019-11-14 11:05:50
字體:
來源:轉載
供稿:網友

1. 原題: https://www.patest.cn/contests/pat-a-PRactise/1046

2. 思路:

題意:在一個環路中,求兩點間的最小距離。基本邏輯題。思路:常規思路是求出總長total,然后累計兩點間的正向距離sum。反向距離是total-sum,輸出兩者的最小值。然而數組規模很大,最后一個測試點超時。改進的思路參考自:http://blog.csdn.net/xyt8023y/article/details/46924653即:另開一個數組,在求total時,保存從起點1到當前點的距離。這樣就少了一層循環。

3. 源碼(已AC):

#include<iostream>#include<algorithm>//使用min,max函數#include<vector>using namespace std;int main(void){	//freopen("in.txt", "r", stdin);	int N, total = 0;	scanf("%d", &N);	vector<int> ev(N + 1, 0);//保存兩點間的距離	vector<int> acc(N + 1, 0);//保存起點到當前點的距離	for (int i = 1; i <= N; i++)	{		acc[i] = total;		scanf("%d", &ev[i]);		total += ev[i];	}	int M, sta, end;//分別為所求問題個數, 起始點,末點。	int lnum, gnum;//分別表示兩點較小的和較大的序號	scanf("%d", &M);	for (int i = 0; i < M; i++)	{		scanf("%d %d", &sta, &end);		lnum = min(sta, end);		gnum = max(sta, end);		int sum = acc[gnum] - acc[lnum];		int min_dist = sum > (total / 2) ? (total-sum) : sum;		printf("%d/n", min_dist);	}	return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜良县| 曲阳县| 探索| 塘沽区| 东宁县| 怀集县| 固原市| 四平市| 新营市| 霍林郭勒市| 周宁县| 海林市| 和平区| 崇文区| 邯郸市| 台北市| 黔江区| 龙陵县| 凭祥市| 额尔古纳市| 望城县| 开原市| 农安县| 阿拉善左旗| 湟中县| 福清市| 蒲江县| 诏安县| 阜阳市| 怀远县| 项城市| 咸丰县| 新丰县| 乐业县| 南靖县| 玉林市| 白水县| 濉溪县| 呼伦贝尔市| 宜宾市| 革吉县|