【10.6NOIP普及模拟】MATH

题目简化

一个数列任意删k个数,是得数列中最大的差+最小的差最小

思路

程序1——时超40

暴搜+剪枝。

用类似排列组合的方式,暴搜删或不删

剪枝就是看看剩下的数,如果还小于k,则退出

程序2.1——时超80

这是suzejia大神教我的:

令m=n-k;(即数列长度)

排序一遍

因为要求最小,并且最大差即为最大数-最小数

所以删后的数列是一个区间,设l为左,r为右。

l=1~k+1;因为r最多为n,长度为m,n-(k+1)+1=m

r=l+m-1;由r-l+1=m变形而来

然后枚举,M=a[r]-a[l],m为相邻数中差最小的(暴力)

ans=min(M+m,ans)

程序2.2——AC

时间超限必定是在l的循环和枚举m的循环中出现的,又因为l是必要的,所以

枚举m时不能暴力。

因此,我用了RMQ

程序实践

C++(Pascal选手对不起)

#include <cstdio>
#include <iostream>
#include <cstring>
#include <cmath>
#include <climits>
#include <algorithm>
using namespace std;
int n,k,m,ans;
int v[200001];
int cha[200001];//cha[i]表示v[i+1]-v[i]
int f[200001][21];//RMQ,f[i][j]表示i到i+2^j-1中最小值
int main()
{
FILE *IN=freopen("math.in","r",stdin);
FILE *OUT=freopen("math.out","w",stdout);
int i,l,r;
scanf("%d%d",&n,&k);
for(i=1;i<=n;i++)
{
scanf("%d",&v[i]);
}
bool cmp(int,int);
make_heap(v+1,v+n+1,cmp);//建堆
sort_heap(v+1,v+n+1,cmp);//堆排序
cha[0]=INT_MAX;
for(i=1;i<=n-1;i++)
cha[i]=v[i+1]-v[i];//cha[i]表示v[i+1]与v[i]的差
void RMQ();
RMQ();//预处理
m=n-k;
ans=INT_MAX;
int ask(int,int);//表示一段区间的最小数
for(l=1;l<=k+1;l++)
{
r=l+m-1;
ans=min(v[r]-v[l]+ask(l,r-1),ans);
}
printf("%d\n",ans);
return 0;
}
bool cmp(int a,int b)
{return (a<b);}
void RMQ()
{
int i,j;
for(i=1;i<=n-1;i++)
f[i][0]=cha[i];
for(j=1;j<=floor(log2(n-1));j++)
{
for(i=1;i<=n-1-(1<<j)+1;i++)
{
f[i][j]=min(f[i][j-1],f[i+(1<<(j-1))][j-1]);
}
}
}
int ask(int l,int r)
{
int x;
x=floor(log2(r-l+1));
return (min(f[l][x],f[r-(1<<x)+1][x]));
}

总结:

有些题目,不要想复杂,要化繁为简,才能找到正解。

【10.6NOIP普及模拟】MATH——枚举法的更多相关文章

  1. 【10.5NOIP普及模拟】sum

    [10.5NOIP普及模拟]sum 文章目录 [10.5NOIP普及模拟]sum 题目描述 输入 输出 输入输出样例 样例输入 样例输出 解析 code 题目描述 小x有很多糖果,分成了 N 堆,排成 ...

  2. 【10.5NOIP普及模拟】sort

    [10.5NOIP普及模拟]sort 文章目录 [10.5NOIP普及模拟]sort 题目描述 输入 输出 输入输出样例 样例输入 样例输出 数据范围限制 解析 code 题目描述 小x和小y是好朋友 ...

  3. OpenJudge计算概论-完美立方【暂时就想到了枚举法了】

    /*===================================== 完美立方 总时间限制: 1000ms 内存限制: 65536kB 描述 a的立方 = b的立方 + c的立方 + d的立 ...

  4. for循环枚举法,全排列+dfs,补充浮点数注意事项

    其实这个题目我一直没想好应该叫什么,就是在做蓝桥杯的时候会遇到很多的题,给你一等式,abcdef...分别是1-9(||12||15)不重复问你有几种方案? 我之前一直都是用的for循环在做,听说这叫 ...

  5. 【NYOJ-187】快速查找素数—— 枚举法、筛选法、打表法

    快速查找素数 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 现在给你一个正整数N,要你快速的找出在2.....N这些数里面所有的素数. 输入 给出一个正整数数N(N ...

  6. PJ可能会考的模拟与枚举-自学教程

    PJ可能会考的模拟与枚举-自学教程 文/Pleiades_Antares 之前学校里看一个小可爱复习的时候偷偷听来着XD 简单记了一下重点吧,希望能对看官您有所帮助XD 以下⬇️是几个复习时讲过的题, ...

  7. 10.17 NOIP模拟赛

    目录 2018.10.17 NOIP模拟赛 A 咒语curse B 神光light(二分 DP) C 迷宫maze(次短路) 考试代码 B 2018.10.17 NOIP模拟赛 时间:1h15min( ...

  8. 算法:枚举法---kotlin

    枚举法:效率低,循环所有的情况,找到正确答案 用于解决数学问题,还是很简单的. 比如,奥数里面: 算 法 描 述 题X题=题题题题题题 其中 算法描述题每一个为一个数字,请写出正确的数字. ok,我们 ...

  9. 清北学堂—2020.1提高储备营—Day 1 morning(模拟、枚举、搜索)

    qbxt Day 1 morning --2020.1.17 济南 主讲:李佳实 目录一览 1.模拟和枚举 2.基础搜索算法(DFS.BFS.记忆化搜索)以及进阶搜索算法(纯靠自学) 总知识点:基础算 ...

随机推荐

  1. servlet的xml配置详解

    <?xml version="1.0" encoding="UTF-8"?><web-app xmlns="http://xmlns ...

  2. 函数的属性和方法, apply和call的区别及bind的使用

    ==>我的新博客中 http://www.suanliutudousi.com/2017/08/27/%E5%87%BD%E6%95%B0%E7%9A%84%E5%B1%9E%E6%80%A7% ...

  3. sql实现查询某个字段在哪个表里 及结构是什么

    ) --数据库名 ) set @dbname2='aab' select @str = ' SELECT 表名=d.name,字段名=a.name,序号=a.column_id, 标识=is_iden ...

  4. C++之变量

    变量 **作用**:给一段指定的内存空间起名,方便操作这段内存 **语法**:数据类型 变量名 = 初始值; 语法:数据类型  变量名 = 初始值;   记得加英文分号结束语句 > 注意:C++ ...

  5. idea引入项目下所有文件(ps:包括静态文件夹)

    打开项目的目录结构 点击finish 最后删除目录下多余的src就可以了

  6. (二十三)Http请求的处理过程

  7. sys_call_table HOOK

    sys_call_table 这个东西,其实和 Windows 下的 SSDT 表,在功能上完全相同. 前一阵子学Linux驱动,遇到了这个系统调用表,然后我就想到Windows的SSDT表,既然SS ...

  8. 2018-10-8-3分钟教你搭建-gitea-在-Centos-服务器

    title author date CreateTime categories 3分钟教你搭建 gitea 在 Centos 服务器 lindexi 2018-10-08 09:54:39 +0800 ...

  9. The linux command之环境

    一.环境 shell在环境中存储了两种数据类型:环境变量(environment variables )shell变量(shell variables).在shell中这两种变量基本没有什么不同. 此 ...

  10. C++ 系列:交换两个数字

    1. 创建中间变量 这是最快也是最简单的办法,例如: #include<stdio.h> int main(){ int a=10; int b=20; int temp; printf( ...