[APIO 2016] Gap:交互式,鸽笼原理

2023-10-20 20:19

本文主要是介绍[APIO 2016] Gap:交互式,鸽笼原理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

讨论闭幕式的时候,大家提议让YJQ神犇上台发表一番获奖感言,YJQ说,他想说两句话:1. T3是社区送温暖题。2. 在座的各位,除了我,都不是垃圾。

最后第一句话说没说我忘记了,第二句是说了的,引起全场唏嘘一片……

虽然没有奖,但还是很开心。那是第一次参加全国性的比赛,看到了许许多多来自祖国五湖四海的神犇。当了一回主持人(虽然台词很少,主要负责PPT),无论是写台词、一起讨论,还是彩排,都是美好的回忆。DZD主席坚持要 one by one 地颁奖,并且金银铜都颁,导致先前准备的游戏全部泡汤……看到NOI 2016给所有获奖选手一个一个颁奖,有不一样的感觉。

YJQ神犇的第二句显然是自谦QAQ 但第一句是真的……

考场上我拿了0分和30分。嗯,量子态。网络太差了,而且我是12点多钟开始写的这一题,直到离开考场的那一刻评测结果都没看到。再加上没有获奖,文件上找不到分数,也许这就是永远的谜了。

第一个子任务,对查询次数做出限制。两边夹,往中间收缩,即可还原出整个序列。

第二个子任务,限制查询次数和查到的数的总数。得换一个思路了。不再想着要还原出整个序列,而是从答案本身入手。我们能得出它的一个范围吗?可以,只要知道整个序列的首项和末项。鸽笼原理!假设答案小于 aNa1N1 ,那么推出 aNa1<aNa1 ,矛盾。因此,答案不小于 ceiling(aNa1N1) a2,a3,,aN1 中,如果存在两项,差小于等于 ceiling(aNa1N1) ,那么这两项之间的项(如果存在)对答案是没有贡献的。

答案也有一个上界: aNa1N+2

听说这道题也可以用倍增来做。但是不知道怎么搞……搞清楚了再来补上。

放代码。第一次交挂成30分,数组开小,RE了。

#include "gap.h"
#include <algorithm>
using namespace std;
const int MAX_N = 100000;
typedef long long ll;
ll a[MAX_N*2];
long long findGap(int T, int N)
{ll ans = 1, s = 0, t = 1e18, mn, mx;int n = 0;if (T == 1) {ll head = 0, tail = N-1;while (head <= tail) {MinMax(s, t, &mn, &mx);a[head++] = mn;a[tail--] = mx;s = mn+1;t = mx-1;}n = N;} else {MinMax(s, t, &mn, &mx);ll d = (mx-mn+N-1)/N, x, y;a[n++] = mn;for (s = mn+1, t = s+d; s < mx; s = t+1, t = s+d) {MinMax(s, min(t, mx-1), &x, &y);if (x == -1)continue;a[n++] = x;a[n++] = y;}a[n++] = mx;}for (int i = 1; i < n; ++i)ans = max(ans, a[i] - a[i-1]);return ans;
}

这篇关于[APIO 2016] Gap:交互式,鸽笼原理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/249483

相关文章

Golang HashMap实现原理解析

《GolangHashMap实现原理解析》HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作,:本文主要介绍GolangH... 目录HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程

SpringShell命令行之交互式Shell应用开发方式

《SpringShell命令行之交互式Shell应用开发方式》本文将深入探讨SpringShell的核心特性、实现方式及应用场景,帮助开发者掌握这一强大工具,具有很好的参考价值,希望对大家有所帮助,如... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

鸿蒙中@State的原理使用详解(HarmonyOS 5)

《鸿蒙中@State的原理使用详解(HarmonyOS5)》@State是HarmonyOSArkTS框架中用于管理组件状态的核心装饰器,其核心作用是实现数据驱动UI的响应式编程模式,本文给大家介绍... 目录一、@State在鸿蒙中是做什么的?二、@Spythontate的基本原理1. 依赖关系的收集2.

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI