题目:
题意:
求按照规则使基地可以防御敌人的入侵的至少要加的围墙的条数
分析:
普通情况用
s
/
2
+
s
%
2
s/2+s\%2
s/2+s%2
特殊地,我们需要对子环的情况进行判断
代码:
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<set>
#include<queue>
#include<vector>
#include<map>
#include<list>
#include<ctime>
#include<iomanip>
#include<string>
#include<bitset>
#include<deque>
#include<set>
#define LL long long
using namespace std;
inline LL read(){
LL d=0,f=1;char s=getchar();
while(s<'0'||s>'9'){if(s=='-')f=-1;s=getchar();}
while(s>='0'&&s<='9'){d=d*10+s-'0';s=getchar();}
return d*f;
}
LL c[100005];
int main()
{
LL n=read(),m=read(),k=read();
for(LL i=1;i<=m;i++)
{
LL a=read(),b=read();
if(a==b) continue;
c[a]++;c[b]++;
}
LL maxm=0,s=0;
for(LL i=1;i<=n;i++)
{
if(c[i]<k)
if(k-c[i]>maxm) s+=maxm,maxm=k-c[i];
else s+=k-c[i];
else;
}
if(maxm>=s) return !printf("%lld",maxm);
s+=maxm;
cout<<s/2+s%2;
return 0;
}