#include<bits/stdc++.h>
using namespace std;
int a[30];int n,k,u=0,r;
int b[1005],book[1005];
void dfs(int t)
{
if(u==1)
{
return;
}
if(t==r)
{
u=0;
int sum=0;
for(int i=0;i<r;i++)
{
sum+=b[i];
}
if(sum==k)
{
for(int i=0;i<r;i++)
{
if(b[i]==0)
{
continue;
}
if(u==0)
{
printf("YES\n");u=1;
}
printf("%d ",b[i]);
}printf("\n");u=1;
}
return;
}
for(int i=0;i<n;i++)
{
if(book[i]==0)
{
book[i]=a[i];
b[t]=a[i];
dfs(t+1);
book[i]=0;
}
}
}
int main()
{
scanf("%d%d",&n,&k);
for(int i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
for(r=n;r>0;r--)
{
memset(b,0,sizeof(b));
memset(book,0,sizeof(book));
if(u==1)
{
break;
}
dfs(0);
}
if(u==0)
{
printf("NO\n");
}
return 0;
}