Cod sursa(job #272406)

Utilizator mihaipoascaPoasca Mihai mihaipoasca Data 6 martie 2009 23:25:50
Problema Triplete Scor 40
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.89 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;

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)
            for(lista k1=L[i];k1;k1=k1->next)
                for(lista k2=L[p->inf];k2;k2=k2->next)
                    if(k1->inf==k2->inf)
                        ++rez;


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



}