uva 11825 - Hackers' Crackdown dp

简介:

 题意

  有n个节点,每个节点有m_i个邻居,每个人和邻居为一个整体,问最多可以分成几组使得每组并集合为全集

转移方程

复杂度 3^n

/*
author:jxy
lang:C/C++
university:China,Xidian University
**If you need to reprint,please indicate the source**
*/
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
using namespace std;
int node[20];
int ans[1<<17],cover[1<<17];//cover 预处理所有状态下集合并情况
int n;
int main()
{
    int C=0;
    while(~scanf("%d",&n)&&n)
    {
        int m,i,j,t;
        for(i=0;i<n;i++)
        {
            node[i]=1<<i;
            scanf("%d",&m);
            for(j=0;j<m;j++)
            {
                scanf("%d",&t);
                node[i]|=1<<t;
            }
        }
        int Max=(1<<n)-1,S,S0;
        for(S=1;S<=Max;S++) //预处理
        {
            cover[S]=0;
            for(i=0;i<n;i++)
                if(S&(1<<i))cover[S]|=node[i];
        }
        for(S=1;S<=Max;S++) //dp
        {
            ans[S]=0;
            for(S0=S;S0;S0=(S0-1)&S)
            {
                if(cover[S0]==Max)ans[S]=max(ans[S],ans[S^S0]+1);
            }
        }
        printf("Case %d: %d\n",++C,ans[S-1]);
    }
}




目录
相关文章
|
负载均衡
《从零开始手写RPC框架》电子书升级啦!
大家好,我是冰河~~ 今天跟大家正式宣布一个好消息,冰河的《从零开始手写RPC框架(基础篇)》电子书,升级啦! 这本电子书中包含哪些内容呢?小伙伴们可以直接拉到文末查看获取方式,也可以先听冰河吹一吹这本电子书的内容。
633 0
《从零开始手写RPC框架》电子书升级啦!
水果软件flstudio设置成中文版本的操作步骤
再也用不着给编曲软件FL Studio安装汉化补丁了,今天FL Studio官方不声不响地悄悄更新了FL Studio 20中文版,但一些朋友装完Mac中文版后发现还是英文版,这是怎么回事呢?今天就俩讲一讲正确安装并设置FL中文版的方法。
2331 0
|
Java Spring
Spring Cloud Alibaba - 26 Gateway-自定义谓词工厂RoutePredicateFactory
Spring Cloud Alibaba - 26 Gateway-自定义谓词工厂RoutePredicateFactory
225 0
|
Android开发
解决圆形进度条ProgressBar的几个问题
Android自带的Progressbar默认就是圆形的,可以通过设置style属性 style="?android:attr/progressBarStyleHorizontal" 复制代码 这样就能变成条状进度条,如下: <ProgressBar android:layout_width="match_parent" android:layout_height="wrap_content" style="?android:attr/progressBarStyleHorizontal"/>
1547 0
|
12月前
|
人工智能 安全 算法
基于C语言的嵌入式系统开发,涵盖嵌入式系统概述、C语言的优势、开发流程、关键技术、应用实例及面临的挑战与未来趋势。
本文深入探讨了基于C语言的嵌入式系统开发,涵盖嵌入式系统概述、C语言的优势、开发流程、关键技术、应用实例及面临的挑战与未来趋势。C语言因其高效、可移植、灵活及成熟度高等特点,在嵌入式系统开发中占据重要地位。文章还介绍了从系统需求分析到部署维护的完整开发流程,以及中断处理、内存管理等关键技术,并展望了嵌入式系统在物联网和人工智能领域的未来发展。
527 1
|
运维 容灾 关系型数据库
介绍几种 MySQL 官方高可用方案
MySQL 官方提供了多种高可用部署方案,从最基础的主从复制到组复制再到 InnoDB Cluster 等等。本篇文章以 MySQL 8.0 版本为准,介绍下不同高可用方案架构原理及使用场景。
3013 3
介绍几种 MySQL 官方高可用方案
|
传感器 消息中间件 网络协议
嵌入式QT- QT使用MQTT
嵌入式QT- QT使用MQTT
|
监控 网络协议 安全
微服务架构的常见问题和解决思路|学习笔记
快速学习微服务架构的常见问题和解决思路
微服务架构的常见问题和解决思路|学习笔记
|
敏捷开发 人工智能 边缘计算