BestCoder Round #86 B NanoApe Loves Sequence

题意:

中文题,题意就算了

思路:

弱的思路…

找一个最大,和第二大,第三大,标记下标(前面那个)

①:如果是1/n的话,最大就是他位置的话,那么就是第二大,

②:中间情况的话,需要判断两个位置是不是满足第一大,或者第一大和第二大都满足,还要和一个新产生的差值比一比。

比赛时的挫code………

#include<iostream>
#include<string.h>
#include<math.h>
#include<cstdio>
#include<algorithm>
using namespace std;
typedef __int64 LL; const int N = 1e5+10; LL a[N];
int main()
{
int t;
scanf("%d",&t);
while(t--)
{ int n,m;
scanf("%d",&n);
for(int i=1; i<=n; i++)
scanf("%I64d",&a[i]);
LL m1=-1,m2=-1,m3=-1;
int p1,p2,p3;
LL x;
for(int i=1; i<n; i++)
{
x=abs(a[i]-a[i+1]);
if(x>m1)
{
m3=m2;
p3=p2;
m2=m1;
p2=p1;
m1=x;
p1=i; continue;
}
if(x>m2)
{
m3=m2;
p3=p2;
m2=x;
p2=i;
continue;
}
if(x>m3)
{
m3=x;
p3=i;
}
}
//printf("%I64d %I64d %I64d\n%d %d %d\n",m1,m2,m3,p1,p2,p3);
LL sum=0;
if(n==3)
{
sum+=abs(a[3]-a[2]);
sum+=abs(a[3]-a[1]);
sum+=abs(a[1]-a[2]);
}
else
for(int i=1; i<=n; i++)
{
if(i==1)
{
if(p1!=i)
sum+=m1;
else
sum+=m2;
}
else if(i==n)
{
if(p1!=i-1)
sum+=m1;
else
sum+=m2;
}
else
{
if(p1!=i-1&&p1!=i)
sum+=max(m1,abs(a[i-1]-a[i+1]));
else if(p1==i-1)
{
if(p2!=i)
sum+=max(m2,abs(a[i-1]-a[i+1]));
else
sum+=max(m3,abs(a[i-1]-a[i+1]));
}
else if(p1==i)
{
if(p2!=i-1)
sum+=max(m2,abs(a[i-1]-a[i+1]));
else
sum+=max(m3,abs(a[i-1]-a[i+1]));
}
}
// printf("%I64d\n",sum);
}
printf("%I64d\n",sum);
}
return 0;
}

hdoj5805【模拟】的更多相关文章

  1. App开发:模拟服务器数据接口 - MockApi

    为了方便app开发过程中,不受服务器接口的限制,便于客户端功能的快速测试,可以在客户端实现一个模拟服务器数据接口的MockApi模块.本篇文章就尝试为使用gradle的android项目设计实现Moc ...

  2. 故障重现, JAVA进程内存不够时突然挂掉模拟

    背景,服务器上的一个JAVA服务进程突然挂掉,查看产生了崩溃日志,如下: # Set larger code cache with -XX:ReservedCodeCacheSize= # This ...

  3. Python 爬虫模拟登陆知乎

    在之前写过一篇使用python爬虫爬取电影天堂资源的博客,重点是如何解析页面和提高爬虫的效率.由于电影天堂上的资源获取权限是所有人都一样的,所以不需要进行登录验证操作,写完那篇文章后又花了些时间研究了 ...

  4. HTML 事件(四) 模拟事件操作

    本篇主要介绍HTML DOM中事件的模拟操作. 其他事件文章 1. HTML 事件(一) 事件的介绍 2. HTML 事件(二) 事件的注册与注销 3. HTML 事件(三) 事件流与事件委托 4.  ...

  5. 模拟AngularJS之依赖注入

    一.概述 AngularJS有一经典之处就是依赖注入,对于什么是依赖注入,熟悉spring的同学应该都非常了解了,但,对于前端而言,还是比较新颖的. 依赖注入,简而言之,就是解除硬编码,达到解偶的目的 ...

  6. webapp应用--模拟电子书翻页效果

    前言: 现在移动互联网发展火热,手机上网的用户越来越多,甚至大有超过pc访问的趋势.所以,用web程序做出仿原生效果的移动应用,也变得越来越流行了.这种程序也就是我们常说的单页应用程序,它也有一个英文 ...

  7. javascript动画系列第一篇——模拟拖拽

    × 目录 [1]原理介绍 [2]代码实现 [3]代码优化[4]拖拽冲突[5]IE兼容 前面的话 从本文开始,介绍javascript动画系列.javascript本身是具有原生拖放功能的,但是由于兼容 ...

  8. C++ 事件驱动型银行排队模拟

    最近重拾之前半途而废的C++,恰好看到了<C++ 实现银行排队服务模拟>,但是没有实验楼的会员,看不到具体的实现,正好用来作为练习. 模拟的是银行的排队叫号系统,所有顾客以先来后到的顺序在 ...

  9. MSYS2——Windows平台下模拟linux环境的搭建

    最近从MSYS1.0迁移到了MSYS2.0,简单讲,MSYS2.0功能更强大,其环境模拟更加符合linux.虽然本身来自cygwin,但其集成了pacman软件管理工具,很有linux范,并且可以直接 ...

随机推荐

  1. Java学习之String StringBuffer StringBuilder区别

    1.String:对象长度是不可变的,是线程安全. 2.StringBuffer:对象长度是可变的,是线程安全. 3.StringBuilder:对象长度是可变,不是线程安全.

  2. Java经常使用类及其经常用法

    1.ArrayList java.util.ArrayList<E> add(E e) //插入尾部 add(int index, E element) remove(int index) ...

  3. LeetCode_3Sum

    一.题目 3Sum Total Accepted: 45112 Total Submissions: 267165My Submissions Given an array S of n intege ...

  4. python 爬虫1 開始,先拿新浪微博開始

    刚刚開始学. 目的地是两个.一个微博,一个贴吧 存入的话,临时还没想那么多.先存到本地目录吧 分词和推荐后面在整合 mysql mongodb hadoop redius 后面在用 我最终知道为什么大 ...

  5. HDU 6078 Wavel Sequence 树状数组优化DP

    Wavel Sequence Problem Description Have you ever seen the wave? It's a wonderful view of nature. Lit ...

  6. sbt is a build tool for Scala, Java, and more

    http://www.scala-sbt.org/0.13/docs/index.html sbt is a build tool for Scala, Java, and more. It requ ...

  7. $.ajax 使用详解

    Jquery在异步提交方面封装的很好,直接用AJAX非常麻烦,Jquery大大简化了我们的操作. $.post.$.get是一些简单的方法,如果要处理复杂的逻辑,还是需要用到jQuery.ajax() ...

  8. 您可能试图从server上的安全浏览器訪问此站点。请启用脚本然后又一次载入此页。

    您可能试图从server上的安全浏览器訪问此站点.请启用脚本然后又一次载入此页.         我使用域Admin组的账户登入SharePoint2010的server,打开SharePoint首页 ...

  9. extjs4 treepanel 多个checkbox先中 多个节点选中 多级节点展开

    //<%@ page contentType="text/html; charset=utf-8" %> var checkedNodes = { _data:{}, ...

  10. 主线程 view

    参考https://blog.csdn.net/u011001142/article/details/50912358