P8687 [蓝桥杯 2019 省 A] 糖果

~~~~~ P8687 [蓝桥杯 2019 省 A] 糖果 ~~~~~ 总题单链接

思路

~~~~~ 发现 k ≤ 20 , m ≤ 20 k\le20,m\le 20 k≤20,m≤20,考虑状压DP。

~~~~~ 预处理 g [ i ] g[i] g[i] 表示第 i i i 包糖有哪几种糖果。

~~~~~ 设 d p [ i ] dp[i] dp[i] 表示在 i i i 状态下最少要买几包糖。

~~~~~ 对于第 i i i 包糖,枚举所有状态 j j j, d p [ g [ i ] ∣ j ] = m i n ( d p [ g [ i ] ∣ j ] , d p [ j ] + 1 ) dp[g[i]|j]=min(dp[g[i]|j],dp[j]+1) dp[g[i]∣j]=min(dp[g[i]∣j],dp[j]+1)。

代码

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long
using namespace std;

ll n,m,Q,g[105],dp[(1ll<<20)+5];

signed main(){
	ios::sync_with_stdio(false);
	
	cin>>n>>m>>Q;
	for(ll i=1;i<=n;i++){
		for(ll j=1;j<=Q;j++){
			ll k;cin>>k;
			g[i]|=(1ll<<(k-1));
		}
	}
	
	memset(dp,0x3f,sizeof(dp));
	dp[0]=0;
	
	for(ll i=1;i<=n;i++)
		for(ll j=(1ll<<m)-1;j>=0;j--)
			dp[g[i]|j]=min(dp[g[i]|j],dp[j]+1);
	
	cout<<(dp[(1ll<<m)-1]<=n?dp[(1ll<<m)-1]:-1);
	
	return 0;
}
相关推荐
lucky九年几秒前
GO语言模拟C++封装,继承,多态
开发语言·c++·golang
北顾笙980几秒前
day12-数据结构力扣
数据结构·算法·leetcode
凌波粒11 分钟前
LeetCode--454.四数相加 II(哈希表)
算法·leetcode·散列表
漫随流水17 分钟前
c++编程:D进制的A+B(1022-PAT乙级)
数据结构·c++·算法
tankeven21 分钟前
HJ159 没挡住洪水
c++·算法
美式请加冰28 分钟前
斐波那契数列介绍和使用
算法
charlie11451419138 分钟前
嵌入式C++教程实战之Linux下的单片机编程:从零搭建 STM32 开发工具链(5):调试进阶篇 —— 从 printf 到完整 GDB 调试环境
linux·c++·单片机·学习·嵌入式·c
paeamecium1 小时前
【PAT】 - Course List for Student (25)
数据结构·c++·算法·pat考试
小黄人软件1 小时前
MFC为什么不报空指针异常 2宏定义不改源码 用替换 用Log函数替换printf等 #define printf Log 优化版底层类Log显示
c++·mfc
wen__xvn1 小时前
力扣洛谷模拟题刷题2
算法·leetcode·职场和发展