Luogu P2915 [USACO08NOV]奶牛混合起来
题外话:
是非常颓废的博主
写题解也不在于能不能通过啦,主要是缓解颓废
首先看到这个题,肯定是可以暴力搜索的:
不得不说这道题还是很善良的,一波大暴力dfs,居然有70pts:
#include<bits/stdc++.h>
using namespace std;
inline int read() {
int ans=0;
char last=' ',ch=getchar();
while(ch>'9'||ch<'0') last=ch,ch=getchar();
while(ch>='0'&&ch<='9') ans=(ans<<1)+(ans<<3)+ch-'0',ch=getchar();
if(last=='-') ans=-ans;
return ans;
}
int n,k;
int s[20];
long long ans;
bool vis[20];
void dfs(int cnt,int nxt) {
if(cnt==n) {
ans++;
return;
}
for(int i=1;i<=n;i++) {
if(vis[i]) continue;
if(abs(s[i]-nxt)>k) {
vis[i]=1;
dfs(cnt+1,s[i]);
vis[i]=0;
}
}
}
int main() {
n=read();
k=read();
for(int i=1;i<=n;i++)
s[i]=read();
dfs(0,-k-1);
printf("%lld",ans);
return 0;
}
想改记忆化,然后我发现我不会
滚回来重新考虑dp:
将奶牛状压到一个二进制数中,第i位表示这头奶牛是否在队伍中;(突兀
我们设 \(dp[i][j]\) 表示当前状态为i,最后一个加入队伍的奶牛是j的方案数;
考虑如何转移:
设现在的状态为 \(dp[i][j]\)
考虑枚举下一个加入队伍的奶牛g是哪一只,那么首先肯定要满足的,就是这只奶牛不能已经加入队伍了 (奶牛:我有分身术 也就是i&(1<<(g-1))==0
1.如果已经在队伍里,显然要continue;(废话
2.如果不在队伍里,那么判断第g头奶牛和第j头奶牛之间的编号之差是否>k,同样的不是就continue掉 (同样的废话
如果上面两个条件都满足,那么就可以将g加入队伍,对应的状态 \(dp[i|(1<<(g-1))][g]+=dp[i][j];\)
考虑初始化:
对于只有一头奶牛的情况,显然只有一种方案,因此 \(dp[1<<(i-1)][i]=1;\)
然后因为上面讲的 非常非常之乱,咱们来理一理思路:
首先显然是初始化,将只有一头奶牛的方案的值初始化为1
接下来枚举每一种状态
第二维枚举当前状态下,最后一个加入队伍的奶牛j是哪一只(可以直接从1~n枚举,用i&(1<<(j-1))!=0来判断合法与否
然后枚举下一头加入队伍的奶牛是哪一头,判断是否符合上面的两个条件,相应的进行修改
最后显然是输出答案啦:显然最后的答案应该是所有奶牛都加入了队伍,每一头奶牛最后进入队伍的方案数相加,也就是 \(\sum\limits_{i=1}^n dp[(1<<n)-1][i]\)
然后,大概应该可能就可以愉快的AC了?(是 码风清奇的奇女子,将就着看吧
#include<bits/stdc++.h>
using namespace std;
inline int read() {
int ans=0;
char last=' ',ch=getchar();
while(ch>'9'||ch<'0') last=ch,ch=getchar();
while(ch>='0'&&ch<='9') ans=(ans<<1)+(ans<<3)+ch-'0',ch=getchar();
if(last=='-') ans=-ans;
return ans;
}
int n,k;
int s[20];
long long ans;
long long dp[70000][18];
int main() {
n=read();
k=read();
for(int i=1;i<=n;i++)
s[i]=read();
for(int i=1;i<=n;i++)
dp[1<<(i-1)][i]=1;
for(int a=1;a<(1<<n);a++) {
for(int j=1;j<=n;j++) {
if(!(a&(1<<(j-1))))
continue;
for(int g=1;g<=n;g++) {
if((a&(1<<(g-1))))
continue;
if(abs(s[j]-s[g])<=k)
continue;
dp[a|(1<<(g-1))][g]+=dp[a][j];
}
}
}
for(int i=1;i<=n;i++)
ans+=dp[(1<<n)-1][i];
printf("%lld\n",ans);
return 0;
}
//一堆括号看的我眼疼
Luogu P2915 [USACO08NOV]奶牛混合起来的更多相关文章
- luogu P2915 [USACO08NOV]奶牛混合起来Mixed Up Cows
题目描述 Each of Farmer John's N (4 <= N <= 16) cows has a unique serial number S_i (1 <= S_i & ...
- 洛谷 P2915 [USACO08NOV]奶牛混合起来Mixed Up Cows 解题报告
P2915 [USACO08NOV]奶牛混合起来Mixed Up Cows 题意: 给定一个长\(N\)的序列,求满足任意两个相邻元素之间的绝对值之差不超过\(K\)的这个序列的排列有多少个? 范围: ...
- 洛谷P2915 [USACO08NOV]奶牛混合起来Mixed Up Cows
P2915 [USACO08NOV]奶牛混合起来Mixed Up Cows 题目描述 Each of Farmer John's N (4 <= N <= 16) cows has a u ...
- 洛谷 P2915 [USACO08NOV]奶牛混合起来Mixed Up Cows
P2915 [USACO08NOV]奶牛混合起来Mixed Up Cows 题目描述 Each of Farmer John's N (4 <= N <= 16) cows has a u ...
- P2915 [USACO08NOV]奶牛混合起来Mixed Up Cows
题目描述 约翰家有N头奶牛,第i头奶牛的编号是Si,每头奶牛的编号都是唯一的.这些奶牛最近 在闹脾气,为表达不满的情绪,她们在挤奶的时候一定要排成混乱的队伍.在一只混乱的队 伍中,相邻奶牛的编号之差均 ...
- 洛谷P2915 [USACO08NOV]奶牛混合起来Mixed Up Cows 状压动归
考场上空间开大了一倍就爆0了QAQ- Code: #include<cstdio> #include<algorithm> #include<cmath> usin ...
- 洛谷 P2915 【[USACO08NOV]奶牛混合起来Mixed Up Cows】
类似于n皇后的思想,只要把dfs表示放置情况的数字压缩成一个整数,就能实现记忆化搜索了. 一些有关集合的操作: {i}在集合S内:S&(1<<i)==1: 将{i}加入集合S:S= ...
- [USACO08NOV]奶牛混合起来Mixed Up Cows
题目描述 Each of Farmer John's N (4 <= N <= 16) cows has a unique serial number S_i (1 <= S_i & ...
- 【[USACO08NOV]奶牛混合起来Mixed Up Cows】
首先我们能够一眼看到4 <= N <= 16,那么就是它了,我们要压缩的状态就是它了 那么之后能我们用这个状态表示什么呢,我们要表示的显然是每只奶牛是否在队伍中 比如说10吧,转成二进制后 ...
随机推荐
- viewport的相关知识点
主要说一些viewport的基本原理以及使用 ㈠概念 手机浏览器是把页面放在一个虚拟的“窗口”(viewport)中,通常这个虚拟的“窗口”(viewport)比屏幕宽,这样就不用把每个网页挤到很小的 ...
- luogu 2993 [FJOI2014]最短路径树问题 Dijkstra+点分治
挺简单的,但是给人一种把两个问题强行弄到一起的感觉. 十分不好写. Code: #include <queue> #include <cstdio> #include < ...
- 关键字static在标准C/C++的作用
static总结:根据作用域,存储域,生命周期3点来说 static含义: 是C/C++中很常用的修饰符,它被用来控制变量的存储方式和可见性. (1)标准C语言中,static的最主要功能是隐藏,其次 ...
- AbpUser 扩展
AbpUser表存放的信息比较少,现扩展一下信息 1.在Core层添加UserExtend 类,继承 AbpUser<User>,写入以上各项属性字段,并添加Discriminator 字 ...
- AtCoder AGC037D Sorting a Grid (二分图匹配)
题目链接 https://atcoder.jp/contests/agc037/tasks/agc037_d 题解 这场D题终于不像AGC032D和AGC036D一样神仙了-- 还是可做的吧 虽然考场 ...
- 微信小程序_简单组件使用与数据绑定
简单的数据传值 官方文档:传送门 点击"按钮"测试后,按钮文本改变,下方text文本改变,通过console.log()在输出台中打印按钮文本信息 程序结构 Page({ //页面 ...
- springboot 使用redis
安装redis教程:https://www.cnblogs.com/nongzihong/p/10190489.html 依赖: <!--配置redis--> <dependency ...
- TreeMap、HashMap、LindedHashMap的区别
LinkedHashMap可以保证HashMap集合有序.存入的顺序和取出的顺序一致.TreeMap实现SortMap接口,能够把它保存的记录根据键排序,默认是按键值的升序排序,也可以指定排序的比较器 ...
- C++入门经典-例5.1-输出变量的指针
1:代码如下: // 5.1.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> using ...
- js中filter过滤用法总结
定义和用法 filter() 方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素. 注意: filter() 不会对空数组进行检测. 注意: filter() 不会改变原始数组 ...