Cod sursa(job #272420)

Utilizator mihaipoascaPoasca Mihai mihaipoasca Data 6 martie 2009 23:57:15
Problema Triplete Scor 50
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.99 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(int k=1;k<=Nmax;k++)
            viz[k]=0;
        for(lista k1=L[i];k1;k1=k1->next)
            viz[k1->inf]=1;

        for(lista p=L[i];p;p=p->next)
            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;



}