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

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

1046. Shortest Distance (20)

2019-11-14 10:14: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;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 虎林市| 钦州市| 新安县| 安徽省| 临泉县| 两当县| 二手房| 河东区| 墨玉县| 崇义县| 措勤县| 天镇县| 贵州省| 兴和县| 岱山县| 富宁县| 沽源县| 枣强县| 岳阳市| 瑞安市| 西青区| 嘉荫县| 泉州市| 三都| 娄底市| 苍南县| 松溪县| 禹州市| 类乌齐县| 抚顺市| 西乌珠穆沁旗| 阆中市| 临湘市| 德兴市| 泰州市| 连山| 汉川市| 湾仔区| 邛崃市| 奉贤区| 内黄县|