记录编号 460486 评测结果 AAAAAAAAAW
题目名称 游历校园 最终得分 90
用户昵称 Gravatar实力演员阵容 是否通过 未通过
代码语言 C++ 运行时间 0.819 s
提交时间 2017-10-17 13:30:22 内存使用 1.95 MiB
显示代码纯文本
#include<cstdio>
#include<vector>
using namespace std;
class G{
public:
	vector<int>s;
}a[101000];
bool vis[101000]={0};
int n,m,sum,ans=0,s;
int d[101000]={0};
void dfs(int r){
	vis[r]=1;
	if(d[r]%2==1)
		sum++;
	for(int i=0;i<a[r].s.size();i++){
		s++;
		if(vis[a[r].s[i]]==0){
			dfs(a[r].s[i]);
		}
	}
}
int main(){
	freopen("sent.in","r",stdin);
	freopen("sent.out","w",stdout);
	scanf("%d%d",&n,&m);
	int x,y;
	for(int i=1;i<=m;i++){
		scanf("%d%d",&x,&y);
		a[x].s.push_back(y);
		a[y].s.push_back(x);
		d[x]++;d[y]++;
	}
	for(int i=1;i<=n;i++){
		if(vis[i]==0){
			sum=0;
			s=0;
			dfs(i);
			if(sum>=2)
				ans+=sum/2-1;
			if(s!=0&&i!=1){
				ans++;
			}
		}
	}
	printf("%d",ans);
}