HDU 2083(排序+绝对值+中间值求和)
简易版之最短距离
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 16700 Accepted Submission(s): 7481
Problem Description
寒假的时候,ACBOY要去拜访很多朋友,恰巧他所有朋友的家都处在坐标平面的X轴上。ACBOY可以任意选择一个朋友的家开始访问,但是每次访问后他都必须回到出发点,然后才能去访问下一个朋友。
比如有4个朋友,对应的X轴坐标分别为1, 2, 3, 4。当ACBOY选择坐标为2的点做为出发点时,则他最终需要的时间为 |1-2|+|2-2|+|3-2|+|4-2| = 4。
现在给出N个朋友的坐标,那么ACBOY应该怎么走才会花费时间最少呢?
Input
输入首先是一个正整数M,表示M个测试实例。每个实例的输入有2行,首先是一个正整数N(N <= 500),表示有N个朋友,下一行是N个正整数,表示具体的坐标(所有数据均<=10000).
Output
对于每一个测试实例,请输出访问完所有朋友所花的最少时间,每个实例的输出占一行。
Sample Input
2
2
2 4
3
2 4 6
Sample Output
2
4
题意简述
本题题意直接明了,不必重复了
题意分析
既然想用时最短,那么肯定要以某个特定的朋友开始。一开始输入的数据不一定是有序的,所以应该先对数组进行排序。
排好序,接下来我们想一下,如果从两边分别开始逐个进行拜访,那么这样用时肯定是最长的,并且时间相等(可以看成每个数字差的绝对值的和,就不给出证明了)。所以可以想到,从中间开始,作为起点,然后向两边进行拜访,这样的时间肯定是最短的(代码实现的时候,只需要找到中间的数,然后从最左边开始遍历求和就行了,不需要从中间开始,分别向左向右求和,这样代码不好实现,也麻烦)。
好了,几本思路形成了,我们注意几个数学问题(数学好的就skip吧)!!
①如果数组单元个数分奇偶,影响找到中间值和结果吗?
Answer:不影响
0 | 1 | 2 |
---|---|---|
2 | 5 | 10 |
这样一组数据,中间值a[mid] = 5
time(min) = 3+5=8
0 | 1 | 2 | 3 |
---|---|---|---|
2 | 5 | 10 | 15 |
有人有疑问了:
mid = m/2 还是 (m-1) / 2 呢?
此时a[mid] = 5或10 那我们分别计算下此时的time(min)
为5的时候time = 3+5+10
为10的时候time = 8+5+5 均为18
所以可以得出结论不影响,证明也很简单,在这里就不赘述了。
②用sort函数报错咋办?
那首先看你下你的文件是不是.cpp,其次看看头文件有没有algorithm,最后看看有没有using namespace std;
(我就忘了+)
代码总览
/*
Title:HDU 2083
Author:pengwill
Date:2016-08-29
Blog:http://blog.csdn.net/pengwill97
*/
#include<stdio.h>
#include<algorithm>
#include<math.h>
using namespace std;
int main()
{
int n;
int a[501];
scanf("%d",&n);
while(n--){
int m,i,mid,sum;
scanf("%d",&m);
for(i = 0; i<m;i++){
scanf("%d",&a[i]);
}
sort(a,a+m);
mid = m/2;
sum = 0;
for(i = 0; i<m;i++){
if(i == mid){
continue;
}else{
sum += abs(a[mid]-a[i]);
}
}
printf("%d\n",sum);
}
return 0;
}
HDU 2083(排序+绝对值+中间值求和)的更多相关文章
- HDU 2083 简易版之最短距离 --- 水题
HDU 2083 简易版之最短距离 /* HDU 2083 简易版之最短距离 */ #include <cstdio> #include <algorithm> using n ...
- hdu 4288 离线线段树+间隔求和
Coder Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Su ...
- java算法面试题:有一个字符串,其中包含中文字符、英文字符和数字字符,请统计和打印出各个字符的个数 按值的降序排序,如果值相同则按键值的字母顺序
package com.swift; import java.util.HashMap; import java.util.Map; import java.util.Map.Entry; publi ...
- SortedDictionary<TKey, TValue> 类 表示根据键进行排序的键/值对的集合。
SortedDictionary<TKey, TValue> 类 表示根据键进行排序的键/值对的集合. SortedDictionary<TKey, TValue> 中的每 ...
- Java Map按键(Key)排序和按值(Value)排序
Map排序的方式有很多种,两种比较常用的方式:按键排序(sort by key), 按值排序(sort by value).1.按键排序jdk内置的java.util包下的TreeMap<K,V ...
- HDU 1106 排序 题解
排序 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submissi ...
- hdu 3466 排序01背包
也是好题,带限制的01背包,先排序,再背包 这题因为涉及到q,所以不能直接就01背包了.因为如果一个物品是5 9,一个物品是5 6,对第一个进行背包的时候只有dp[9],dp[10],…,dp[m], ...
- HashMap按键排序和按值排序
对map集合进行排序 今天做统计时需要对X轴的地区按照地区代码(areaCode)进行排序,由于在构建XMLData使用的map来进行数据统计的,所以在统计过程中就需要对map进行排序. 一.简单 ...
- java -- 对Map按键排序、按值排序
java -- 对Map按键.按值排序 1.按键排序(sort by key) 直接上代码 ↓ public Map<String, Str ...
随机推荐
- CentOS 7.2静默安装Oracle11g
Preface Today I'm gonna export some test data to another server.The source server is Windows ...
- centos下php环境安装redis
一.安装redis(仅可在服务器使用,尚不能通过浏览器访问) (1)首先下载redis:wget http://download.redis.io/releases/redis-4.0.9.tar.g ...
- gdb超级基础教程
GDB超级基础教程 为什么叫超级基础呢,因为我被坑了一把.... 编译选项带 -g 就可以在可执行程序中加入调试信息,然后就可以使用gdb去查看了. 使用help命令就可以看到: (gdb) help ...
- Bootstrap框架(图标)
Glyphicons 字体图标 所有可用的图标 包括250多个来自 Glyphicon Halflings 的字体图标.Glyphicons Halflings 一般是收费的,但是他们的作者允许 Bo ...
- HADOOP docker(九):hdfs权限
1. 概述2. 用户身份标识3. 组映射4.关于权限的实现5.文件系统API的变更6.应用程序shell的变更7.超级用户8.ACLs9.ACL 文件系统API10.ACL命令11.参数配置12.总结 ...
- HADOOP docker(七):hive权限管理
1. hive权限简介1.1 hive中的用户与组1.2 使用场景1.3 权限模型1.3 hive的超级用户2. 授权管理2.1 开启权限管理2.2 实现超级用户2.3 实现hiveserver2用户 ...
- HTML5form表单的相关知识总结
首先在介绍HTML5form表单的新增内容之前,我总结了一下HTML的form表单的内容. <!DOCTYPE html> <html lang="en"> ...
- Python—列表(一个“打了激素”的数组)
我们在C语言中会使用数组来将一大堆数据类型一样的数据挨个摆在一起,但是数组有一个基本的要求,就是数据类型必须是一致的,我们知道Python的变量由于没有数据类型,也就是说Python没有数组这一概念, ...
- Java 集合框架之 Map
Hashtable Hashtable 的实例有两个参数影响其性能:初始容量 和加载因子.容量 是哈希表中桶 的数量,初始容量就是哈希表创建时的容量.注意,哈希表的状态为 open:在发生“哈希冲突” ...
- oracle数据库之触发器
触发器是许多关系数据库系统都提供的一项技术.在 ORACLE 系统里,触发器类似过程和函数,都有声明,执行和异常处理过程的 PL/SQL 块. 一. 触发器类型 触发器在数据库里以独立的对象存储,它与 ...