Cod sursa(job #272409)

Utilizator mihaipoascaPoasca Mihai mihaipoasca Data 6 martie 2009 23:33:54
Problema Triplete Scor 40
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.98 kb
#include<stdio.h>
#include<string.h>
#define Nmax 4100
#define Mmax 6600

FILE *fin=fopen("triplete.in","r"),
    *fout=fopen("triplete.out","w");

int N,M,rez;
char viz[Nmax];

struct nod{int inf;nod* next;};
typedef nod* lista;
lista L[Nmax];

int main(){
    fscanf(fin,"%d %d",&N,&M);

    for(int i=1;i<=M;i++){
        int x,y;
        fscanf(fin,"%d %d",&x,&y);


        lista aux=new nod;
        aux->inf=x;
        aux->next=L[y];
        L[y]=aux;

        aux=new nod;
        aux->inf=y;
        aux->next=L[x];
        L[x]=aux;

    }

    for(int i=1;i<=N;i++)
        for(lista p=L[i];p;p=p->next){
            memset(viz,0,sizeof(viz));
            for(lista k1=L[i];k1;k1=k1->next)
                viz[k1->inf]=1;
            for(lista k2=L[p->inf];k2;k2=k2->next)
                    if(viz[k2->inf])
                        ++rez;
        }

    fprintf(fout,"%d\n",rez/6);
    fclose(fin);
    fclose(fout);
    return 0;



}