sgu 196

题目不难,关键是要搞清楚矩阵AT*A的含义是什么,然后再利用下点的度数和边的关系就搞定了。

#include <cstdio>
#include <vector>
using namespace std;


template<typename T, typename T2>
void makeVector(T & a, int len, const T2 & initV) {
  a.resize(len);
  for (int i = 0; i < a.size(); ++i) a[i] = initV;
}

vector< int > adjEdgeNum;
int N;
int M;


void run() {
  scanf("%d %d", &N, &M);
  makeVector(adjEdgeNum, N + 1, 0);
  int i, start, end;
  int ans = 0;
  for (i = 1; i <= M; ++i) {
    scanf("%d %d", &start, &end);
    ans = ans + adjEdgeNum[start] * 2 + adjEdgeNum[end] * 2;
    adjEdgeNum[start]++;
    adjEdgeNum[end]++;
  }

  ans = ans + M * 2;

  printf("%d\n", ans);

}

int main() {
  run();
  return 0;
}

转载于:https://my.oschina.net/mustang/blog/56451

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值