编程之美2015初赛_质数相关(二分图)

质数相关

题意:求二分图的最大独立集(独立集就是图中任意两个顶点都不相连的顶点集合)

思路:交替染色法,两种颜色把图染色。颜色最多的即为最大独立集。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<queue>
#include<set>
#include<map>
#include<vector>
#include<cmath>
#define ll __int64
#define INF 0x3fffffff
using namespace std;

vector<vector<int> >G(1005);
int a[1005];
int vis[1005];
int n;
int tm[1005];
int Max=0;

int is_prime(int m)
{
        int k=sqrt(m);
        if(m==2||m==3) return 1;
        else for(int i=2;i<=k;i++)
        if(m%i==0) return 0;
        return 1;
}

void dfs(int x,int color)
{
    if(x==n-1) return;
    vis[x]=1;
    for(int i=0;i<G[x].size();i++){
        int e=G[x][i];
        if(!vis[e]){
            if(tm[e]==0){
                tm[e]=-color;
                color=-color;
                dfs(e,color);
            }
        }
    }
}

int main()
{
    //freopen("d:\\Test.txt","r",stdin);
    int T;
    int t=1;
    cin>>T;
    while(T--){
        scanf("%d",&n);
        for(int i=0;i<n;i++){
            scanf("%d",&a[i]);
        }
        for(int i=0;i<1005;i++) G[i].clear();
        sort(a,a+n);
        int m=0;
        for(int i=0;i<n;i++){
            for(int j=i+1;j<n;j++){
                if(a[j]%a[i]==0){
                    if(is_prime(a[j]/a[i])){
                        G[i].push_back(j);
                        m++;
                    }
                }
            }
        }
        int ans=0;
        memset(tm,0,sizeof(tm));
        memset(vis,0,sizeof(vis));
        for(int i=0;i<n;i++){
            if(tm[i]==0&&!vis[i]){
                tm[i]=-1;
                dfs(i,-1);
            }
        }
        int t1=0,t2=0;
        for(int i=0;i<n;i++){
            if(tm[i]==-1) t1++;
            if(tm[i]==1) t2++;
        }
        //cout<<t1<<" "<<t2<<endl;
        ans=max(t1,t2);
        cout<<"Case #"<<t++<<": "<<ans<<endl;
    }
    return 0;
}
时间: 2024-08-04 02:47:07

编程之美2015初赛_质数相关(二分图)的相关文章

hiho 编程之美2015初赛第一场(质数相关-2分图匹配)

两个数a和 b (a<b)被称为质数相关,是指a × p = b,这里p是一个质数.一个集合S被称为质数相关,是指S中存在两个质数相关的数,否则称S为质数无关.如{2, 8, 17}质数无关,但{2, 8, 16}, {3, 6}质数相关.现在给定一个集合S,问S的所有质数无关子集中,最大的子集的大小. 输入 第一行为一个数T,为数据组数.之后每组数据包含两行. 第一行为N,为集合S的大小.第二行为N个整数,表示集合内的数. 输出 对于每组数据输出一行,形如"Case #X: Y"

编程之美2015初赛第一场 题解

[A题] 彩色的树 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 给定一棵n个节点的树,节点编号为1, 2, -, n.树中有n - 1条边,任意两个节点间恰好有一条路径.这是一棵彩色的树,每个节点恰好可以染一种颜色.初始时,所有节点的颜色都为0.现在需要实现两种操作: 1. 改变节点x的颜色为y: 2. 询问整棵树被划分成了多少棵颜色相同的子树.即每棵子树内的节点颜色都相同,而相邻子树的颜色不同. 输入 第一行一个整数T,表示数据组数,以下是T组数据. 每组数据第

编程之美2015初赛第一场BC

题目2 : 建造金字塔 时间限制:4000ms 单点时限:2000ms 内存限制:256MB 描述 在二次元中,金字塔是一个底边在x轴上的等腰直角三角形. 你是二次元世界的一个建筑承包商.现在有N个建造订单,每个订单有一个收益w,即建造此金字塔可获得w的收益.对每个订单可以选择建造或不建造. 建造一个金字塔的成本是金字塔的面积,如果两个或多个金字塔有重叠面积,则建造这些金字塔时重叠部份仅需建造一次. 建造一组金字塔的总利润是收益总和扣除成本.现给出这些订单,请求出最大利润. 输入 输入数据第一行

hihocoder 编程之美2015初赛第一场 (树算法 + 暴力思想 + 搜索思想)

题目1 : 彩色的树 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 给定一棵n个节点的树,节点编号为1, 2, …, n.树中有n - 1条边,任意两个节点间恰好有一条路径.这是一棵彩色的树,每个节点恰好可以染一种颜色.初始时,所有节点的颜色都为0.现在需要实现两种操作: 1. 改变节点x的颜色为y: 2. 询问整棵树被划分成了多少棵颜色相同的子树.即每棵子树内的节点颜色都相同,而相邻子树的颜色不同. 输入 第一行一个整数T,表示数据组数,以下是T组数据. 每组数据

编程之美2015初赛第二场AB

题目1 : 扑克牌 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 一副不含王的扑克牌由52张牌组成,由红桃.黑桃.梅花.方块4组牌组成,每组13张不同的面值.现在给定52张牌中的若干张,请计算将它们排成一列,相邻的牌面值不同的方案数. 牌的表示方法为XY,其中X为面值,为2.3.4.5.6.7.8.9.T.J.Q.K.A中的一个.Y为花色,为S.H.D.C中的一个.如2S.2H.TD等. 输入 第一行为一个整数T,为数据组数. 之后每组数据占一行.这一行首先包含一个

编程之美2015初赛第一场: 彩色的树

题目1 : 彩色的树 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 给定一棵n个节点的树,节点编号为1, 2, …, n.树中有n - 1条边,任意两个节点间恰好有一条路径.这是一棵彩色的树,每个节点恰好可以染一种颜色.初始时,所有节点的颜色都为0.现在需要实现两种操作: 1. 改变节点x的颜色为y: 2. 询问整棵树被划分成了多少棵颜色相同的子树.即每棵子树内的节点颜色都相同,而相邻子树的颜色不同. 输入 第一行一个整数T,表示数据组数,以下是T组数据. 每组数据

编程之美2015初赛第二场 c题 八卦的小冰

题意:根据给出的各个用户之间的亲密度,计算所有异性对的亲密度总和. 思路:大数据怕太大,所以用邻接表保存这个无向图,在输入时顺便统计亲密度总和.对于更改性别:统计一下该用户的异性朋友的亲密度总和,再总计一下该用户同性朋友的亲密度总和,两者作差,再更新一下总亲密度.对于更改亲密度:要考虑改为0的情况,就是两用户没有关系了,图中删除这条边,根据亲密度的增加或减少,总亲密度也要相应增加或减少.要查询时直接输出.这样应该能应对全是3的情况.个人想法! 1 #include <iostream> 2 #

hihocoder 微软编程之美2015 初赛 第二场(暴力+字典序+图论+思维算法)

题目1 : 扑克牌 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 一副不含王的扑克牌由52张牌组成,由红桃.黑桃.梅花.方块4组牌组成,每组13张不同的面值.现在给定52张牌中的若干张,请计算将它们排成一列,相邻的牌面值不同的方案数. 牌的表示方法为XY,其中X为面值,为2.3.4.5.6.7.8.9.T.J.Q.K.A中的一个.Y为花色,为S.H.D.C中的一个.如2S.2H.TD等. 输入 第一行为一个整数T,为数据组数. 之后每组数据占一行.这一行首先包含一个

编程之美2015 round2a c 二分图最大独立集

题目描述: 两个数a和b(a<b)被称为质数相关,是指a × p = b,这里p是一个质数.一个集合S被称为质数相关,是指S中存在两个质数相关的数,否则称S为质数无关.如{2, 8, 17}质数无关,但{2, 8, 16}, {3, 6}质数相关.现在给定一个集合S,问S的所有质数无关子集中,最大的子集的大小. 思路: 最大独立集,大致分析了一下感觉是二分图,没有详细证明,不过大数据过了,应该是对的吧,求大神证明是二分图. 1 #include <iostream> 2 #include