CF888E Maximum Subsequence (Meet in the middle,贪心)
题目链接
Solution
Meet in the middle.
考虑到 \(2^{35}\) 枚举会超时,于是分成两半枚举(尽量平均).
然后不能 \(n^2\) 去匹配,需要用到一点贪心:
将数分成 \(p,q\) 两组,那么对于任意数 \(p_i\) ;
它与 \(q\) 数组中组成最大得到的值即为
最大的与 \(p_i\) 之和不超过\(m\) 的数.
然后就可以贪心优化了.
还要注意一点就是最大的两个也要考虑一次.
Code
#include<bits/stdc++.h>
#define N 1<<20
#define ll long long
using namespace std;
ll n,m,w[40],p[N],q[N],ans;
ll cntp,cntq,a[40],b[40];
void dfs1()
{
ll num=(n+1)/2;
for(ll i=0;i<num;i++)a[i]=w[i*2+1];
ll tot=(1<<num)-1;
for(ll i=1;i<=tot;i++)
{
ll Tot=0;
for(ll j=0;j<num;j++)
if((1<<j)&i)
Tot+=a[j],Tot%=m;
p[++cntp]=Tot;
}
}
void dfs2()
{
ll num=n/2;
for(ll i=0;i<num;i++)
b[i]=w[(i+1)*2];
ll tot=(1<<num)-1;
for(ll i=1;i<=tot;i++)
{
ll Tot=0;
for(ll j=0;j<num;j++)
if((1<<j)&i)
Tot+=b[j],Tot%=m;
q[++cntq]=Tot;
}
}
int main()
{
scanf("%lld%lld",&n,&m);
for(ll i=1;i<=n;i++)
scanf("%lld",&w[i]);
sort(w+1,w+n+1);
dfs1(); dfs2();
sort(p+1,p+cntp+1);
sort(q+1,q+cntq+1);
//for(ll i=1;i<=cntp;i++)cout<<p[i]<<' ';cout<<endl;
//for(ll i=1;i<=cntq;i++)cout<<q[i]<<' ';cout<<endl;
int i=0,j=cntq;
while(i<=cntp){
while(p[i]+q[j]>=m) --j;
ans=max(ans,p[i]+q[j]),++i;
}//贪心优化部分
ans=max(ans,(p[cntp]+q[cntq])%m);
cout<<ans<<endl;
}
CF888E Maximum Subsequence (Meet in the middle,贪心)的更多相关文章
- $CF888E\ Maximum\ Subsequence$ 搜索
正解:$meet\ in\ the\ middle$ 解题报告: 传送门$QwQ$. 发现数据范围为$n\leq 35$,所以$2^{\frac{n}{2}}$是可做的. 所以先拆成$A,B$两个集合 ...
- CF888E Maximum Subsequence(meet in the middle)
给一个数列和m,在数列任选若干个数,使得他们的和对m取模后最大( \(1<=n<=35\) , \(1<=m<=10^{9}\)) 考虑把数列分成两份,两边分别暴力求出所有的可 ...
- [CF888E] Maximum Subsequence 序列分治
早期作品,不喜轻喷. LG传送门 序列分治板子题. 切这道题用了好长时间,所以想发篇题解作为纪念 . 首先,我们认真观察题目数据(面向数据做题是个好习惯),发现题目的\(n\)竟然只有\(35\),我 ...
- 【CF888E】Maximum Subsequence(meet in the middle)
[CF888E]Maximum Subsequence(meet in the middle) 题面 CF 洛谷 题解 把所有数分一下,然后\(meet\ in\ the\ middle\)做就好了. ...
- 【CF888E】Maximum Subsequence 折半搜索
[CF888E]Maximum Subsequence 题意:给你一个序列{ai},让你从中选出一个子序列,使得序列和%m最大. n<=35,m<=10^9 题解:不小心瞟了一眼tag就一 ...
- Codeforces Round #648 (Div. 2) E. Maximum Subsequence Value 贪心
题意:E.Maximum Subsequence Value 题意: 给你n 个元素,你挑选k个元素,那么这个 k 集合的值为 ∑2i,其中,若集合内至少有 max(1,k−2)个数二进制下第 i 位 ...
- Meet in the middle学习笔记
Meet in the middle(MITM) Tags:搜索 作业部落 评论地址 PPT中会讲的很详细 当搜索的各项互不影响(如共\(n\)个物品前\(n/2\)个物品选不选和后\(n/2\)个物 ...
- Educational Codeforces Round 32:E. Maximum Subsequence(Meet-in-the-middle)
题目链接:E. Maximum Subsequence 用了一个Meet-in-the-middle的技巧,还是第一次用到这个技巧,其实这个技巧和二分很像,主要是在dfs中,如果数量减小一半可以节约很 ...
- 1007 Maximum Subsequence Sum
Given a sequence of K integers { N1, N2, ..., NK }. A continuous subsequence is defined to ...
随机推荐
- Java自定义异常信息
通常在开发过程中,会遇到很多异常,对于一些知道异常的原因,这时候想要返回给浏览器,就需要自定义系统的异常 1.Spring 注入异常处理类 <bean id ="commonExce ...
- Servlet学习笔记02——什么是http协议?
1.http协议 (了解) (1)什么是http协议? 是一种网络应用层协议,规定了浏览器与web服务器之间 如何通信以及相应的数据包的结构. 注: a.tcp/ip: 网络层协议,可以保证数据可靠的 ...
- Nginx无法加载.woff .eot .svg .ttf等解决办法
在Nginx的配置文件,加上以下代码即可修复该问题 location ~ \.(eot|otf|ttf|woff|svg)$ { add_header Access-Control-Allow-Ori ...
- CSS设置背景透明字体不透明
写CSS时给容器设置透明度的时候如果使用background-color: #000000; opacity: 0.5;这时会出现容器里的文字也跟着透明.解决办法是不用十六进制的色值和透明度分开写,使 ...
- 【转载】C++中的static关键字的总结
本文前半部分转自:博主chao_yu 本文后半部分转自:博主VincentCZW 静态变量作用范围在一个文件内,程序开始时分配空间,结束时释放空间,默认初始化为0,使用时可以改变其值. 静态变量或静态 ...
- 【LeetCode #179】Largest Number 解题报告
原题链接:Largest Number 题目描述: Given a list of non negative integers, arrange them such that they form th ...
- C# 输出结果有System.Byte[]
byte[]类型直接输出或者调用ToString函数都会出现这个结果. 需要执行: byte[] a=new byte[10]; string text = "";for (int ...
- 1,VMware与Centos系统安装
选择性 pc可以选择 -纯系统 Linux/windows -双系统 Windows+Linux -虚拟化技术 Windows+vmware workstation 服务器 -物理机纯系统 -物理机+ ...
- Windows系统安装测试redis
因本人电脑是windows系统,从https://github.com/ServiceStack/redis-windows下载了兼容windows系统的redis 下载后直接解压到D:\redis目 ...
- git命令行操作详解
目录 1.常用操作 1.1 新建代码库 1.2 配置 1.3 remote管理 1.4 添加和撤销操作 1.5 代码提交 1.6 分支操作 1.7 查看信息 1.8 pull操作 1.9 push操作 ...