【10.6NOIP普及模拟】MATH——枚举法
【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——枚举法的更多相关文章
- 【10.5NOIP普及模拟】sum
[10.5NOIP普及模拟]sum 文章目录 [10.5NOIP普及模拟]sum 题目描述 输入 输出 输入输出样例 样例输入 样例输出 解析 code 题目描述 小x有很多糖果,分成了 N 堆,排成 ...
- 【10.5NOIP普及模拟】sort
[10.5NOIP普及模拟]sort 文章目录 [10.5NOIP普及模拟]sort 题目描述 输入 输出 输入输出样例 样例输入 样例输出 数据范围限制 解析 code 题目描述 小x和小y是好朋友 ...
- OpenJudge计算概论-完美立方【暂时就想到了枚举法了】
/*===================================== 完美立方 总时间限制: 1000ms 内存限制: 65536kB 描述 a的立方 = b的立方 + c的立方 + d的立 ...
- for循环枚举法,全排列+dfs,补充浮点数注意事项
其实这个题目我一直没想好应该叫什么,就是在做蓝桥杯的时候会遇到很多的题,给你一等式,abcdef...分别是1-9(||12||15)不重复问你有几种方案? 我之前一直都是用的for循环在做,听说这叫 ...
- 【NYOJ-187】快速查找素数—— 枚举法、筛选法、打表法
快速查找素数 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 现在给你一个正整数N,要你快速的找出在2.....N这些数里面所有的素数. 输入 给出一个正整数数N(N ...
- PJ可能会考的模拟与枚举-自学教程
PJ可能会考的模拟与枚举-自学教程 文/Pleiades_Antares 之前学校里看一个小可爱复习的时候偷偷听来着XD 简单记了一下重点吧,希望能对看官您有所帮助XD 以下⬇️是几个复习时讲过的题, ...
- 10.17 NOIP模拟赛
目录 2018.10.17 NOIP模拟赛 A 咒语curse B 神光light(二分 DP) C 迷宫maze(次短路) 考试代码 B 2018.10.17 NOIP模拟赛 时间:1h15min( ...
- 算法:枚举法---kotlin
枚举法:效率低,循环所有的情况,找到正确答案 用于解决数学问题,还是很简单的. 比如,奥数里面: 算 法 描 述 题X题=题题题题题题 其中 算法描述题每一个为一个数字,请写出正确的数字. ok,我们 ...
- 清北学堂—2020.1提高储备营—Day 1 morning(模拟、枚举、搜索)
qbxt Day 1 morning --2020.1.17 济南 主讲:李佳实 目录一览 1.模拟和枚举 2.基础搜索算法(DFS.BFS.记忆化搜索)以及进阶搜索算法(纯靠自学) 总知识点:基础算 ...
随机推荐
- Java-Class-@I:org.apache.ibatis.annotations.Mapper
ylbtech-Java-Class-@I:org.apache.ibatis.annotations.Mapper 1.返回顶部 2.返回顶部 1. package com.ylbtech.ed ...
- iOS开发inputView和inputAccessoryView
1.简介 起初看到这两个属性是在UIResponder中,只是可读的: @property (nullable, nonatomic, readonly, strong) __kindof UIVie ...
- webstorm快捷键、支持vue文件等部分使用技巧
转载:https://www.cnblogs.com/seven077/p/9771474.html 1.常用快捷键 shift+↑ 向上选取代码块shift+↓ 向下选取代码块ctrl+/ 注释/取 ...
- maven-version
<java.version>1.8</java.version><project.build.sourceEncoding>UTF-8</project.bu ...
- C#中ORM的简单实现
ORM在功能上主要有两个: 把从数据库中查询返回的DataSet,DataTable转化为我们可以方便使用的实体类集合: 把要对数据库操作的实体类集合或条件转化为数据库可以直接执行的SQL语句.
- Eclipse代替Oracle接管Java EE
Eclipse Foundation接替Oracle成为Java EE的新东家,Oracle不再管理Java EE. 作为采用的一部分,Java EE可能会更换新名称,Oracle建议在其建议中使用J ...
- Task 暂停与继续
static void Main(string[] args) { CancellationTokenSource tokenSource = new CancellationTokenSource( ...
- Java 巴什博弈(取石子报数问题)
巴什博弈:有一堆n个物品,两个人轮流从这堆物品中取物,规定每次至少取一个,最多取m个.最后取光者得胜. 规律:如果n=m+1,那么由于一次最多只能取m个,所以,无论先取者拿走多少个,后取者都能够一 ...
- 廖雪峰Java16函数式编程-2Stream-7其他操作
1. 排序 Stream<T> sorted(); //按元素默认大小排序(必须实现Comparable接口) Stream<T> sorted(Comparator<? ...
- 暴力贪心+预处理自动机——cf990E
枚举每种灯管,然后找到代价最小的那种灯管 贪心策略:灯管从0开始向右放置,如果末尾是不能放置灯管的结点,那么要往回找到最近一个可以放置灯管的结点,在那里放置灯管 所以先预处理每个不能放置灯管的结点对应 ...