HDU

来源:互联网 发布:蒲城网络党校 编辑:程序博客网 时间:2024/04/28 02:20
///tooYang了, 直接每次枚举题目就重复计算很多次了,  预处理一下题目的枚举, 就可以A了#include <iostream>#include <cstdio>#include <queue>#include <cstring>#include <cmath>#include <vector>#include <set>#include <stack>#include <algorithm>//#include "myAlgorithm.h"#define MAX 10005#define OFFENCE (1e9 + 5)#define INF (1e8 + 5)#define eps 1e-9#define Rep(s, e) for( int i = s; i <= e; i++)#define Cep(e, s) for( int i = e; i >= s; i --)#define PI acos(-1.0)//#pragma comment(linker, "/STACK:36777216") ///传说中的外挂using namespace std;int N, M , K;int p[MAX];vector<int>pro[20];int stu[MAX];bool getStu(int allCan){    int ans = 0;    Rep(0, N - 1){        if((stu[i] & allCan) == allCan){            ans ++;        }    }    return ans >= K;}bool isFind;void check002(int len, int allCan, int count, int pos){    if(isFind)return ;    if(count == len && getStu(allCan)){///搜索树中的1的个数为len的节点需要判断            isFind = true;            return ;    }    if( pos >=M || count > len){        return ;    }///搜索结束    check002(len, allCan | (1<< pos), count + 1, pos + 1);    check002(len, allCan, count, pos + 1);    ///枚举二进制数, 当前两个分支, 要么放1, 要么放0}///------------------------直接搜索TLE掉了--------/** 借鉴了亮神的程序, 预处理对题目的枚举, 减少,重复计算次数, 这样就很快了*////-----------------------------------------再换check- 增加预处理-----------void shown(int val){   for(int i = 0; i < 15; i++){        cout<<(val &1 )<<" ";        val >>= 1;    }cout<<endl;}bool v[MAX];void dfs(int len, int count, int pos, int val){    if(count == len){        pro[len].push_back(val);    }    if(count > len)return ;    v[pos] = 1;    for(int i = pos + 1; i <= 15; i++){        if(!v[i]){            dfs(len, count + 1, i, val | 1<<(i - 1));        }    }    v[pos] = 0;}void makeList( )///预处理题目枚举{    for(int i = 1; i <= 15; i++){        dfs(i, 0, 0, 0);    }}bool check003(int num){    int len = pro[num].size();    Rep(0, len - 1){        int ans = 0;        for(int j = 0; j < N; j++){            if((pro[num][i] & stu[j]) == pro[num][i]){                ans ++;            }        }        if(ans >= K)            return true;    }    return false;}int find(){    int d = 1, u = M, mid;///    int ans = 0;    while(u - d >= 0){///        mid = (d + u)/2;        if(check003(mid)){///选择mid个题,  然后枚举mid, 看是否存在>=K人做出            ans = max(ans, mid);            d = mid + 1;        }else {            u = mid - 1;        }    }    return ans;}int main() {    makeList( );//    cout<<pro[14].size()<<endl;//    Rep(0, pro[14].size() - 1){//        shown(pro[14][i]);//    }    //freopen("in.tx0t", "w", stdout);    while(scanf("%d %d %d", &N, &M, &K) != EOF){        int pp, pt;        Rep(0, N - 1){           scanf("%*s %d", &pp);            stu[i] = 0;            for(int j = 0; j < pp; j++){                scanf("%d", &pt);                stu[i] |= (1<<(pt - 1));            }        }        printf("%d\n", find());    }    return 0;}/**/


 

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 十八岁了下门牙活动疼痛怎么办 烫完头发后掉头发很厉害怎么办 16岁的孩孑得了肺炎怎么办 我的头发掉的很厉害怎么办 八个月宝宝头后面没头发怎么办 生完孩子掉头发很厉害怎么办 生完孩子后掉头发很厉害怎么办 头发又细又软又卷怎么办 后颈部没有头发掉光了想植发怎么办 头发掉的厉害怎么办怎么拯救掉头发 头发可以种植吗 如果是秃顶怎么办 染头发把手指甲染黑了怎么办 怀孕两个月下体流褐色分泌物怎么办 头发总是大把大把的得掉 怎么办 严重脱发怎么办去问南宁肤康 脱发严重怎么办去看南宁肤康 前额头发少怎么办 如何使头发增多 生完宝宝头发一把一把的掉怎么办 生完宝宝后头发掉的厉害怎么办 生完宝宝头发掉的厉害怎么办 生了小孩后头发掉很多怎么办 生了孩子头发掉的很厉害怎么办 母乳期头发掉的很厉害怎么办 宝宝吃母乳头发掉的厉害怎么办 头发油腻头皮屑多还掉头发怎么办 头发剪了中分刘海弯了怎么办 头发掉了长出来的头发很细怎么办? 头皮损伤毛囊怎么办还会长头发吗 一岁宝宝头发稀少怎么办能刮光头么 前编头发长了怎么办怎么梳理 九个月宝宝头发稀少不长怎么办 前牙吃饭咬合很深吃饭就痛怎么办 吃了甜的冷的就牙疼怎么办 吃热的凉的甜的牙疼怎么办 头发太细了想让头发变粗点怎么办 我的头发又少又很油该怎么办 头发油掉发头顶头发稀疏怎么办 我的头发天生就少又细怎么办 头发越来越少怎么办 用什么好呢 头发油掉头发怎么办吃什么药好 生完孩子三个月掉头发很厉害怎么办