zoukankan      html  css  js  c++  java
  • [HDU5961] 传递

    题目

    原题地址

    解说

    可以总结出(edge[a] & edge[b] = edge[b])
    a连得边的集合交上b连的边的集合=b连得边的集合。
    处理集合的交集就用(bitset)就好了。

    代码

    #include<bits/stdc++.h>
    using namespace std;
    const int  maxn = 2022;
    const int maxm = maxn*maxn;
    struct node{
        int v,next;
    }edge[maxm];
    int head[maxn] ,cnt;
    int n;
    char mp[maxn][maxn];
    bitset<maxn>b[maxn];
    void add_edge(int u,int v){
        edge[cnt].v = v, edge[cnt].next = head[u];
        head[u] = cnt++;
        b[u][v] = 1;
    }
    bool legal(char ch){
        memset(head,-1,sizeof(head));
        cnt = 0;
        for(int i=1;i<=n;i++) b[i].reset();
        for(int i=1;i<=n;i++){
            for(int j=1;j<=n;j++){
                if(mp[i][j] == ch){
                    add_edge(i,j);
                }
            }
        }
        for(int i=1;i<=n;i++){
            for(int j=head[i];j+1;j = edge[j].next){
                int v = edge[j].v;
                if((b[i] & b[v] )!= b[v]) return 0;
            }
        }
        return 1;
    }
    int main(){
        int t;scanf("%d",&t);
        while(t--){
            scanf("%d",&n);
            for(int i=1;i<=n;i++){
                scanf("%s",mp[i] + 1);
            }
            if(legal('P') && legal('Q')){
                printf("T
    ");
            }
            else
                printf("N
    ");
        }
        return 0;
    }
    

    幸甚至哉,歌以咏志。

  • 相关阅读:
    有nativeQuery = true和没有的区别
    itext隐藏table的单元格边框
    Semaphore (参考资料,还没细看)
    STL 一级/二级空间配置器
    内联函数
    死锁
    用户态和内核态
    关于变量的可见性和生命周期
    主从库原理
    xx亿数据处理
  • 原文地址:https://www.cnblogs.com/DarthVictor/p/12928784.html
Copyright © 2011-2022 走看看