【链接】 我是链接,点我呀:)

【题意】

在这里输入题意

【题解】

每个数字有3种选择。
1.选中它。
2.选中它且加阶乘符号
3.不选中它(即计算和的时候不考虑它)

如果我们直接暴力写的话复杂度是\(3^{25}\)

寻求优化。

我们可以用Meet-in-the-middle这个方法。

先求出1..n/2这些数字的组合方式。

用map<ll,ll> dic[25]来存它们的和。

dic[i][j]表示前n/2个数字中选了i个【2】状态的数字,和为j的方案数。

则我们再穷举n/2+1..n这些数字的选择情况。

得到了和sum以及【2】状态的数字个数cnt之后。

答案累加\(∑_0^{k-cnt}dic[i][m-sum]\)

这样复杂度就是\(O(3^{12})\)级别的了。

完全可以接受了

(n=1的时候,n/2等于0,如果你的dfs里面写的条件是now==n/2,应该把它改为now>=n/2,如果不这么改的话,dic[0][0]=1这个会漏掉,

然后右半边就可能会漏解了)

【代码】

#include <bits/stdc++.h>
#define ll long long
using namespace std; const int N = 1e6;
const int M = 25;
const int MM = 200e4; int n,k,a[M+10],bo[M+10],tt;
ll pre[M+10],m,ans;
vector<ll>b[M+1]; int get_num(int cnt,ll x){
int l = 0,r = b[cnt].size()-1,temp1=-1,temp2=-1; while (l <= r){
int mid = (l+r)>>1;
if (x<=b[cnt][mid]){
temp1 = mid;
r = mid-1;
}else l = mid+1;
} l = 0,r = b[cnt].size()-1;
while (l <= r){
int mid = (l+r)>>1;
if (x>=b[cnt][mid]){
temp2 = mid;
l = mid+1;
}else r = mid-1;
} if (temp1==-1 || temp2 ==-1 || b[cnt][temp1]!=x) return 0;
else return temp2-temp1+1;
} void dfs(int now,int ope){
int st,en;
if (ope==1)
st = 1,en = n/2;
else
st = n/2+1,en = n;
if (now>=en+1){
ll sum = 0;
int cnt = 0;
for (int i = st;i <= en;i++){
if (bo[i]==0) continue;
if (bo[i]==2){
if (a[i]>=19) return;
sum+=pre[a[i]];
cnt++;
}else sum+=a[i];
}
if (sum > m) return;
if (ope==1){
b[cnt].push_back(sum);
}else{
for (int i = 0;i <= k-cnt;i++) {
ans+=get_num(i,m-sum);
}
}
return;
} bo[now] = 0;
dfs(now+1,ope); bo[now] = 1;
dfs(now+1,ope); bo[now] = 2;
dfs(now+1,ope);
} int main()
{
#ifdef LOCAL_DEFINE
freopen("rush_in.txt","r",stdin);
#endif
ios::sync_with_stdio(0),cin.tie(0);
pre[0] = 1;
for (int i = 1; ;i++){
pre[i] = pre[i-1]*i;
if (pre[i]>1e16+10) break;
}
cin >> n >> k >> m;
for (int i = 1;i <= n;i++) cin >> a[i];
dfs(1,1);
for (int i = 0;i <= k;i++) sort(b[i].begin(),b[i].end());
dfs(n/2+1,2);
cout<<ans<<endl;
return 0;
}

【Henu ACM Round#18 E】Anya and Cubes的更多相关文章

  1. 【Henu ACM Round#18 F】Arthur and Walls

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 考虑,为什么一个连通块里面的空格没有变成一个矩形? 如果不是形成矩形的话. 肯定是因为某个2x2的单张方形里面. 只有一个角是墙.其 ...

  2. 【Henu ACM Round#18 D】Looksery Party

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 假设现在每个人收到的信息条数存在cnt里面 那个人猜的条数为target 则如果cnt[i]==target[i] 则我们就让第i个 ...

  3. 【Henu ACM Round#18 C】Ilya and Sticks

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 用cnt[i]记录数字i出现的次数就好. 然后i从1e6逆序到1 如果cnt[i+1]和cnt[i]>0同时成立的话. 那么得 ...

  4. 【Henu ACM Round#18 B】Modulo Sum

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] m比较小 <=1000 a[i]直接看成a[i]%m就可以了. 有n个0..999之间的整数.. 如果有一个0那么就直接输出Y ...

  5. 【Henu ACM Round#18 A】 Multiplication Table

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 遍历i从1..n 看看x%i==0以及x/i<=n是否成立. [代码] #include <iostream> u ...

  6. 【Henu ACM Round#24 D】Iterated Linear Function

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 把B提取出来就是一个等比数列了. 求和一下会发现是这种形式. \(B*\frac{(A^n-1)}{A-1}+A^n*x\) 则求一 ...

  7. 【Henu ACM Round#17 D】Hexagons!

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 题目的图吓人. 找下规律就会发现从内到外是1,6,12,18 即1,16,26,36... 即1+6(1+2+3+...) 等差求和 ...

  8. 【Henu ACM Round#14 D】Kefa and Dishes

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 状态压缩动规. 可以写成记忆化搜索的形式. f[bit][p] 表示选取的菜的情况为bit(用0..2^(N)-1的二进制形式表示各 ...

  9. 【Henu ACM Round#24 E】Connected Components

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 要求把连续的一段li..ri的边全都删掉. 然后求剩下的图的联通数 如果暴力的话 复杂度显然是O(k*m)级别的. 考虑我们把li. ...

随机推荐

  1. PHP第九课 正則表達式在PHP中的使用

    今天内容 1.正則表達式 2.数学函数 3.日期函数 4.错误处理 正則表達式: 1.模式修正符 2.五个经常使用函数 另外一个正則表達式的站点:http://www.jb51.net/tools/z ...

  2. 【JS】怎样用原生JS实现jQuery的ready方法

    Jquery中$(document).ready()的作用类似于传统JavaScript中的window.onload方法,只是与window.onload方法还是有差别的. 总的来说,window. ...

  3. 使用ShareSDK实现第三方授权登录、分享以及获取用户资料效果,项目中包含:源码+效果图+项目结构图

    [Android应用开发详解]第01期:第三方授权认证(一)实现第三方授权登录.分享以及获取用户资料   由于公司项目的需要,要实现在项目中使用第三方授权登录以及分享文字和图片等这样的效果,几经波折, ...

  4. javascript中如何获取对象名

    javascript中如何获取对象名 一.总结 一句话总结:将对象传入参数,看参数是否为函数(js中的对象和函数是一个意思么(函数肯定是对象)),对象参数.name属性即可获得 //版本4 funct ...

  5. json的认识及对json数据的相互转化

    Json 和 Jsonlib 的使用 什么是 Json JSON(JvaScript Object Notation)(官网网站:http://www.json.org/)是 一种轻量级的数据交换格式 ...

  6. 基于opencv的手写数字字符识别

    摘要 本程序主要参照论文,<基于OpenCV的脱机手写字符识别技术>实现了,对于手写阿拉伯数字的识别工作.识别工作分为三大步骤:预处理,特征提取,分类识别.预处理过程主要找到图像的ROI部 ...

  7. 使用google API之前需要對input 做什麼 安全性的處理?

    我正要使用node.js 和 google map api做一个小应用,Google MAP API的使用URL如下: https://maps.googleapis.com/maps/api/pla ...

  8. jQuery的一些选择器

    一.基本选择器 1. id选择器(指定id元素) 将id="one"的元素背景色设置为黑色.(id选择器返单个元素) $(document).ready(function () { ...

  9. NOIP2013 货车运输 倍增

    问题描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物,司机们想知道每辆车在不超过车辆限重的情况下,最多能 ...

  10. [NOI2015]品酒大会(SA数组)

    [NOI2015]品酒大会 题目描述 一年一度的"幻影阁夏日品酒大会"隆重开幕了.大会包含品尝和趣味挑战 两个环节,分别向优胜者颁发"首席品酒家"和" ...