提交时间:2023-11-06 21:48:21

运行 ID: 109179

#include<bits/stdc++.h> using namespace std; bool cmp(int a,int b){ return a>b; } int m,s,c,x,a[205],cnt,ans; bool b[205],b1[205]; int main(){ cin>>m>>s>>c; for(int i=1;i<=c;i++){ cin>>x; if(!b[x])cnt++; b[x]=1; ans=max(ans,x); } if(m>=cnt){ cout<<cnt; return 0; } for(int i=1;!b[i];i++){ ans--; } for(int i=1;i<=ans;i++){ if(b1[i])continue; for(int j=i;j<=ans;j++){ b1[j]=1; if(b[j+1]){ a[i]=j-i; break; } } } sort(a+1,a+s+1,cmp); for(int i=1;i<m;i++){ ans-=a[i]; } cout<<ans; return 0; }