首页 > 代码库 > 杭电 2083 简易版之最短距离
杭电 2083 简易版之最短距离
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2083
解题思路:看到数据不大,直接算出每一种不同起点对应的距离找出最小值就可以了
反思:其实最开始看到题目,想的是,将这一组数按升序排列好,然后中间的那几个点就很有可能是距离小的点,后来想到点与点的距离也不是均衡的,所以不能这样做
#include<stdio.h>#include<math.h>#include<stdlib.h>int main(){ int ncase,n; int a[500]; int i; long long sum=0; while(scanf("%d",&ncase)!=EOF) { while(ncase--) { int j=0; long long min=5000000; scanf("%d",&n); for(i=0;i<n;i++) scanf("%d",&a[i]); for(i=0;i<n;i++) { sum=0; for(j=0;j<n;j++) { sum+=abs(a[i]-a[j]); } if(sum<min) min=sum; } printf("%lld\n",min); } }}
杭电 2083 简易版之最短距离
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。