简单的贪心。知道从什么地方贪心是最好的就行了。
#include<stdio.h>
#include<iostream>
#include<string.h>
#include<math.h>
#include<algorithm>
using namespace std;
int main()
{
int n,ans;
int a[503];
bool flag[503];
while(scanf("%d",&n)!=EOF)
{
scanf("%d",&ans);
int sum=ans;
for(int i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
sort(a,a+n);
memset(flag,false,sizeof(flag));
for(int i=0;i<n;i++)
{
if(sum<a[i])
{
flag[i]=true;
sum+=2;
}
}
for(int i=0;i<n;i++)
{
if(!flag[i])sum++;
}
printf("%d\n",sum);
}
return 0;
}