zoj 1011 NTA

数据读入可真让我想了好半天,酝酿好久才敢开写,又一次证明小心总是没错的。

过了样例后,一直WA,奇怪了好久,看了网上的代码才想起,我忘了清vector了,吃一堑长一智吧。。。。。

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<vector>
#define MAX 151
using namespace std;
typedef struct node{
    int a,b;
    };
int n,m,k,L,r[2050];
vector<node> tab[MAX][MAX];
void readIn(){
    int i,j,x,t;
    char c;
    node q;
    for(i=0;i<n;i++){
        for(j=0;j<k;j++){
            x=0;  t=0;  c=getchar();
            while(c!='\n'){
                if(c>='0'&&c<='9'){
                    x*=10;  x+=(c-'0');
                }else{
                    if(t%2==0)q.a=x;
                    else {
                        q.b=x;
                        tab[i][j].push_back(q);
                    }
                    t++,x=0;
                }
                c=getchar();
            }
            q.b=x;
            tab[i][j].push_back(q);
        }
    }
}
int func(int x,int y){
    int i,j;
    node h;
    if(r[y*2]==-1&&r[y*2+1]==-1){
        for(i=0;i<tab[x][ r[y] ].size();i++){
            h=tab[x][ r[y] ].at(i);
            if(h.a>=n-m&&h.b>=n-m)return 1;
        }
    }else{
        for(i=0;i<tab[x][ r[y] ].size();i++){
            h=tab[x][ r[y] ].at(i); 
            if(func(h.a,y*2)==1&&func(h.b,y*2+1)==1)
                return 1;
        }       
    }
    return 0;
}                            
int main(){
    int i,j,t,cas=0; char c; node x;
    while(scanf("%d %d %d",&n,&m,&k),n&&m&&k){
        if(cas>0)printf("\n");
        getchar();
        for(i=0;i<MAX;i++)
            for(j=0;j<MAX;j++)tab[i][j].clear();
        readIn();  
        printf("NTA%d:\n",++cas);
        while(scanf("%d",&L)&&L!=-1){
            getchar();
            j=1;
            memset(r,-1,sizeof(r));
            for(i=0;i<=L;i++){
                c=getchar();
                while(c!='\n'){
                    if(c!=' '){ 
                        if(c!='*') r[j++]=c-'a';
                        else j++;
                    }
                    c=getchar();
                }
            } 
            if(func(0,1)==1)printf("Valid\n");
            else printf("Invalid\n");
        }
    }       
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值