题目链接


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,贪心)的更多相关文章

  1. $CF888E\ Maximum\ Subsequence$ 搜索

    正解:$meet\ in\ the\ middle$ 解题报告: 传送门$QwQ$. 发现数据范围为$n\leq 35$,所以$2^{\frac{n}{2}}$是可做的. 所以先拆成$A,B$两个集合 ...

  2. CF888E Maximum Subsequence(meet in the middle)

    给一个数列和m,在数列任选若干个数,使得他们的和对m取模后最大( \(1<=n<=35\) , \(1<=m<=10^{9}\)) 考虑把数列分成两份,两边分别暴力求出所有的可 ...

  3. [CF888E] Maximum Subsequence 序列分治

    早期作品,不喜轻喷. LG传送门 序列分治板子题. 切这道题用了好长时间,所以想发篇题解作为纪念 . 首先,我们认真观察题目数据(面向数据做题是个好习惯),发现题目的\(n\)竟然只有\(35\),我 ...

  4. 【CF888E】Maximum Subsequence(meet in the middle)

    [CF888E]Maximum Subsequence(meet in the middle) 题面 CF 洛谷 题解 把所有数分一下,然后\(meet\ in\ the\ middle\)做就好了. ...

  5. 【CF888E】Maximum Subsequence 折半搜索

    [CF888E]Maximum Subsequence 题意:给你一个序列{ai},让你从中选出一个子序列,使得序列和%m最大. n<=35,m<=10^9 题解:不小心瞟了一眼tag就一 ...

  6. Codeforces Round #648 (Div. 2) E. Maximum Subsequence Value 贪心

    题意:E.Maximum Subsequence Value 题意: 给你n 个元素,你挑选k个元素,那么这个 k 集合的值为 ∑2i,其中,若集合内至少有 max(1,k−2)个数二进制下第 i 位 ...

  7. Meet in the middle学习笔记

    Meet in the middle(MITM) Tags:搜索 作业部落 评论地址 PPT中会讲的很详细 当搜索的各项互不影响(如共\(n\)个物品前\(n/2\)个物品选不选和后\(n/2\)个物 ...

  8. Educational Codeforces Round 32:E. Maximum Subsequence(Meet-in-the-middle)

    题目链接:E. Maximum Subsequence 用了一个Meet-in-the-middle的技巧,还是第一次用到这个技巧,其实这个技巧和二分很像,主要是在dfs中,如果数量减小一半可以节约很 ...

  9. 1007 Maximum Subsequence Sum

    Given a sequence of K integers { N​1​​, N​2​​, ..., N​K​​ }. A continuous subsequence is defined to ...

随机推荐

  1. javascript常用代码片段

    /** * * @desc 判断两个数组是否相等 * @param {Array} arr1 * @param {Array} arr2 * @return {Boolean} */ function ...

  2. 【JS】window.print打印指定内容

    有时候网页用到打印但是不想打印所有内容,就需要只打印指定内容,下面简单演示下如何打印指定内容 1.在需要打印的指定内容的头部前面加“<!--startprint-->”,在尾部后面加上“& ...

  3. PHP 输出控制

    一.前言 说到PHP输出控制, 在很多框架里面,比如说TP,Yii和Laraval的模版引擎里面都有输出控制函数的阴影,输出控制也叫输出缓冲,说到它的作用有以下几点. 二.内容 1. 输出模版 $va ...

  4. 使用shell脚本依据分区信息分批次的下载hive表格数据

    今天的业务场景大概是这样的,我想把hive表格下载到本地文件系统,然后把这个文件传送到另一个服务器上. 但是这个业务场景一个核心问题就是说我本地机器内存有限,hive表格大概是70G,我是不可能全部下 ...

  5. Codeforces146D 概率DP

    Bag of mice The dragon and the princess are arguing about what to do on the New Year's Eve. The drag ...

  6. HDU 6386 Age of Moyu

    Problem Description Mr.Quin love fishes so much and Mr.Quin’s city has a nautical system,consisiting ...

  7. ABAP自定义截取字符串长度函数

    SAP 中strlen()只能计算字符串的个数,不能计算含有中文字符串的长度,如字符串“SAP大波霸”,strlen('SAP大波霸') = 6,其实真实长度为3+3*2 = 9.我们可以通过cl_a ...

  8. SAPバリアント

    SAPバリアント   VARI バリアント VARID バリアント一覧 VARIT バリアントテキスト VARIS バリアント割当 TVARV バリアント変数(クライアント非依存) TVARVC バリ ...

  9. android 事件传递机制

    有三个方法: dispatchTouchEvent onInterceptTouchEvent onTouchEvent 首先:A的dispatchTouchEvent-A的onInterceptTo ...

  10. ScrollView中ViewPager无法正常滑动问题

    本文主要介绍如何解决ViewPager在ScrollView中滑动经常失效.无法正常滑动问题. 解决方法只需要在接近水平滚动时ScrollView不处理事件而交由其子View(即这里的ViewPage ...