Pagini recente » Cod sursa (job #2903225) | Cod sursa (job #1534022) | Cod sursa (job #1728863) | Cod sursa (job #2694039) | Cod sursa (job #27536)
Cod sursa(job #27536)
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define nmax 4096
#define mmax 65536
#define LSB(a) (a^(a-1)&a)
int n,m,i,j,a[mmax],b[mmax],k,sol;
char adj[nmax][nmax/8],x;
int main()
{
freopen("triplete.in","r",stdin);
freopen("triplete.out","w",stdout);
scanf("%d%d",&n,&m);
for (i=0;i<m;i++)
{
scanf("%d%d",a+i,b+i);
--a[i],--b[i];
adj[a[i]][b[i]/8]|=1<<b[i]%8;
adj[b[i]][a[i]/8]|=1<<a[i]%8;
}
for (i=0;i<m;i++)
{
for (j=0;j<n/8+(n%8?1:0);j++)
{
x=adj[a[i]][j]&adj[b[i]][j];
/* while (x>0)
++sol,x-=LSB(x);*/
if (x&1) ++sol;
if (x&2) ++sol;
if (x&4) ++sol;
if (x&8) ++sol;
if (x&16) ++sol;
if (x&32) ++sol;
if (x&64) ++sol;
if (x&128) ++sol;
}
}
printf("%d\n",sol/3);
return 0;
}