结论:若$a_{n}-a_{1}\ge a_{2}$,那么一定会吃掉

证明:分类讨论,若$a_{n-1}$也吃掉了$a_{2}$,就说明$a_{n-1}$之后不会被吃掉,而$a_{n-1}-a_{2}\le a_{n}-a_{1}$,因此$a_{n}$也不会被吃掉;若$a_{n-1}$不吃$a_{2}$,那么$a_{n}$同样也不会被吃掉

(注意,这只是说明满足这一条件下一定会吃,而不是吃一定要满足此条件)

根据这个结论,可以模拟直至$a_{n}-a_{1}<a_{2}$

考虑接下来是否会吃,如果有$a_{n-1}-(a_n-a_{1})\ge a_{2}$,那么一定不会吃(吃了$a_{n-1}$就一定可以吃他),类似的,如果$a_{n-1}-a'_{1}<a_{2}$且$a_{n-2}-a''_{1}\ge a_{2}$,那么一定可以吃(因为$a_{n-1}$一定不会吃)……

换言之,$a_{n}$吃掉$a_{1}$当且仅当下一次出现$a_{n'}-a_{1}\ge a_{2}$时$n$与$n'$同奇偶,正确性可以归纳得到,同时下一次$n-1$与$n'$就不同奇偶了,即不能吃掉

如何维护这个过程,对两部分分别维护:

1.对于第一部分,即每一次都有$a_{n}-a_{1}<a_{2}$,将所有点分为经过操作和未经过操作两部分,根据上面证明的过程,越晚经过操作的越小,因此用一个队列维护两部分,最小值和最大值都可以得到

2.对于第二部分,直接令$a_{1}=a_{n}-a_{1}$即可(当然要判断一下)

还有一些特殊情况,主要是关于$n=2$时的判断

1.对于第一部分,即模拟直到$a_{n}-a_{1}<a_{2}$,若最终$n=2$,则答案为1(可证一定有$a_{n}\ge \sum_{i=1}^{n-1}a_{i}$);

2.对于第二部分,即模拟直到$a_{n}-a_{1}\ge a_{2}$,若最终$n'=1$,令$n'=2$

 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 1000005
4 #define fi first
5 #define se second
6 set<pair<int,int> >s;
7 deque<pair<int,int> >q1,q2;
8 int t,n,m,x,y,a[N];
9 pair<int,int> b[N];
10 int calc(int n){
11 q1.clear(),q2.clear();
12 for(int i=1;i<=n;i++)q1.push_back(make_pair(a[i],i));
13 pair<int,int>x,y,z;
14 while (1){
15 if (n==2)return 1;
16 if ((q2.empty())||(q1.back()>q2.back())){
17 x=q1.back();
18 q1.pop_back();
19 }
20 else{
21 x=q2.back();
22 q2.pop_back();
23 }
24 y=q1.front();
25 q1.pop_front();
26 z=make_pair(x.fi-y.fi,x.se);
27 if (((q1.empty())||(q1.front()>z))&&((q2.empty())||(q2.front()>z))){
28 q1.push_front(y);
29 q1.push_back(x);
30 break;
31 }
32 n--;
33 q2.push_front(z);
34 }
35 int nn=0;
36 while ((!q1.empty())||(!q2.empty()))
37 if ((!q1.empty())&&((q2.empty())||(q1.front()<q2.front()))){
38 b[++nn]=q1.front();
39 q1.pop_front();
40 }
41 else{
42 b[++nn]=q2.front();
43 q2.pop_front();
44 }
45 while (nn>2){
46 x=make_pair(b[nn].fi-b[1].fi,b[nn].se);
47 if (x>=b[2])break;
48 b[1]=x;
49 nn--;
50 }
51 return n-((n&1)==(nn&1));
52 }
53 int main(){
54 scanf("%d%d",&t,&n);
55 for(int i=1;i<=n;i++)scanf("%d",&a[i]);
56 printf("%d\n",calc(n));
57 t--;
58 while (t--){
59 scanf("%d",&m);
60 for(int i=1;i<=m;i++){
61 scanf("%d%d",&x,&y);
62 a[x]=y;
63 }
64 printf("%d\n",calc(n));
65 }
66 return 0;
67 }

[luogu7078]贪吃蛇的更多相关文章

  1. Android快乐贪吃蛇游戏实战项目开发教程-01项目概述与目录

    一.项目简介 贪吃蛇是一个很经典的游戏,也很适合用来学习.本教程将和大家一起做一个Android版的贪吃蛇游戏. 我已经将做好的案例上传到了应用宝,无病毒.无广告,大家可以放心下载下来把玩一下.应用宝 ...

  2. 用C++实现的贪吃蛇游戏

    我是一个C++初学者,控制台实现了一个贪吃蛇游戏. 代码如下: //"贪吃蛇游戏"V1.0 //李国良于2016年12月29日编写完成 #include <iostream& ...

  3. [LeetCode] Design Snake Game 设计贪吃蛇游戏

    Design a Snake game that is played on a device with screen size = width x height. Play the game onli ...

  4. JavaScript-简单的贪吃蛇小游戏

    实现逻辑: //获取Html中的格子(行,列) //建立数组存储所有格子(x,y) //建立数组用于存储蛇身(x,y) //生成随机坐标(x,y)的函数 //随机创建蛇身并存储到蛇身数组 //创建食物 ...

  5. juery实现贪吃蛇的游戏

    今天用juery做了一个贪吃蛇的游戏,代码比较简陋,不过作为这些天学习juery的成果,非常有成就感.另外关于代码内容如有雷同不胜荣幸. 更改了下 让头和身子的颜色不一样 这样好区分些,虽然还是不怎么 ...

  6. HTML 5 背离贪吃蛇 写成了类似于屏幕校准

    中间写了改 改了写 还是没做出自己满意的效果 ,看来自己的确不是一个走前端的料子.当然h5还是学一点好一点 具体说来 就是 在canvas 的画布中 鼠标点击后画上一个圆形 然后就有随机的在画布上面出 ...

  7. 控制台游戏引擎CGE——贪吃蛇

    今天我也来发一个控制台游戏.先看图: 缘起 LZ是一个有严重拖延症的人,表现的形式就是隔一段时间就要刷一刷博客园. 这不前几天,看到了魏大师<使用Lua脚本语言开发出高扩展性的系统...> ...

  8. 原生JS制作贪吃蛇小游戏

    感情都在代码里,来,干了!... <!doctype html> <html> <head> <meta http-equiv="Content-T ...

  9. 基于AT89C51单片机的贪吃蛇电子游戏(仿真)

    有关贪吃蛇的历史发展可以看一下这个网址,贪吃蛇最初的设计和现在并不相同..http://www.techweb.com.cn/internet/2013-02-21/1278055.shtml 该项目 ...

随机推荐

  1. 我在阿里巴巴做 Serverless 云开发平台

    技术的成熟度源自大规模的实践,Java 领域,阿里将自身的实践源源不断的反哺给微服务技术体系:Node.js 领域,阿里正掀起了前所未有的前端革命浪潮,将实践反哺给 Serverless技术体系,并逐 ...

  2. 看动画学算法之:平衡二叉搜索树AVL Tree

    目录 简介 AVL的特性 AVL的构建 AVL的搜索 AVL的插入 AVL的删除 简介 平衡二叉搜索树是一种特殊的二叉搜索树.为什么会有平衡二叉搜索树呢? 考虑一下二叉搜索树的特殊情况,如果一个二叉搜 ...

  3. Java基础之(七):Scanner对象

    用户交互Scanner Scanner对象 调用java.util.Scanner 可以通过Scanner类来获取用户的输入 基本语法: Scanner scanner = new Scanner(S ...

  4. LOJ6469 Magic(trie)

    纪念我菜的真实的一场模拟赛 首先看到这个题目,一开始就很毒瘤.一定是没有办法直接做的. 我们考虑转化问题 假设,我们选择枚举\(x\),其中\(x\)是\(10\)的若干次方,那么我们只需要求有多少对 ...

  5. Python&Selenium 数据驱动测试【unittest+ddt+xml】

    一.摘要 本博文将介绍Python和Selenium做自动化测试时,基于unittest框架,借助ddt模块,使用xml文件作为测试输入. 二.xml文件 保存路径:D:\\Programs\\Pyt ...

  6. SudokuSolver 1.0:用C++实现的数独解题程序 【二】

    本篇是 SudokuSolver 1.0:用C++实现的数独解题程序 [一] 的续篇. CQuizDealer::loadQuiz 接口实现 1 CQuizDealer* CQuizDealer::s ...

  7. Spark解决SQL和RDDjoin结果不一致问题(工作实录)

    问题描述:DataFrame的join结果不正确,dataframeA(6000无重复条数据) join dataframeB(220条无重复数据,由dataframeA转化而来,key值均源于dat ...

  8. Java Filter型内存马的学习与实践

    完全参考:https://www.cnblogs.com/nice0e3/p/14622879.html 这篇笔记,来源逗神的指点,让我去了解了内存马,这篇笔记记录的是filter类型的内存马 内存马 ...

  9. Java:并发笔记-01

    Java:并发笔记-01 说明:这是看了 bilibili 上 黑马程序员 的课程 java并发编程 后做的笔记 1. 进程与线程 本章内容 进程和线程的概念 并行和并发的概念 线程基本应用 1.1 ...

  10. the Agiles Scrum Meeting 2

    会议时间:2020.4.10 21:00 1.每个人的工作 今天已完成的工作 yjy:debug:班级创建了个人项目不能访问班级:教师窗口的前端bug. issues:Bug:教师创建博客时显示项目为 ...