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

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

1046. Shortest Distance (20)

2019-11-14 10:08:54
字體:
來源:轉載
供稿:網友

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;}
上一篇:枚舉

下一篇:MD5加密

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 微博| 广安市| 榆社县| 平陆县| 夹江县| 焉耆| 五家渠市| 东安县| 皮山县| 壶关县| 永济市| 达尔| 石河子市| 同德县| 夏河县| 醴陵市| 镇沅| 龙门县| 杭锦后旗| 和田县| 黔东| 关岭| 垫江县| 富民县| 仪征市| 白沙| 卓尼县| 延吉市| 西乌| 奎屯市| 山阳县| 旬阳县| 阳山县| 会理县| 临澧县| 司法| 六安市| 孟村| 德昌县| 千阳县| 河曲县|