【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. Java-Class-I:com.alibaba.fastjson.JSONObject

    ylbtech-Java-Class-I:com.alibaba.fastjson.JSONObject 1.返回顶部 1.1.import com.alibaba.fastjson.JSON;imp ...

  2. SecureCRT是最常用的终端仿真程序,简单的说就是Windows下登录UNIX或Liunx服务器主机的软件,本文主要介绍SecureCRT的使用方法和技巧

    SecureCRT是最常用的终端仿真程序,简单的说就是Windows下登录UNIX或Liunx服务器主机的软件,本文主要介绍SecureCRT的使用方法和技巧 VanDyke CRT 和 VanDyk ...

  3. postgresql+java数据类型对照

    网上搜了很多都不理想,这里总结的一部分是官网的文档,一部分是网上的,大体没问题 PostgreSQL™                 Java SE 8 date            LocalD ...

  4. Python匹马行天下之初识python!

    python的发展史 1989年,被称为龟叔的Guido在为ABC语言写插件时,产生了写一个简洁又实用的编程语言的想法,并开始着手编写.因为其喜欢Monty Python喜剧团,所以将其命名为pyth ...

  5. await和async

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  6. Java动态代理与CGLib

    Java帝国之动态代理 CGLib:从兄弟到父子-动态代理在民间是怎么玩的? 以上两篇文章引用自微信公众号: 码农翻身 Java动态代理 深度详解 以上文章引用博客园:陈树义

  7. sslforfree的证书合并成类似于certbot的ssl证书文件

    之前的證書都是通過 certbot的命令生成的,但是目前一個服務器太多個網站,太多個ssl證書,證書過期之後,目前是 通過 ssl for free 網站再生成新的 ssl證書,再次更新證書週期 Le ...

  8. iptbales无法正常重启

    新主机iptables无法启动关闭和重启 一般是由于没有配文件导致 解决办法 直接touch /etc/sysconfig/iptables 然后就可以正常启动. 备注:一般存在于centos6系列中

  9. (转载)js引擎的执行过程(一)

    概述 js是一种非常灵活的语言,理解js引擎的执行过程对我们学习javascript非常重要,但是网上讲解js引擎的文章也大多是浅尝辄止或者只局部分析,例如只分析事件循环(Event Loop)或者变 ...

  10. LUOGU P3161 [CQOI2012]模拟工厂 (贪心)

    传送门 解题思路 贪心,首先因为\(n\)比较小,可以\(2^n\)枚举子集.然后判断的时候就每次看后面的如果用最大生产力生产能不能达成目标,解一个二次函数. 代码 #include<iostr ...