#include <bits/stdc++.h>
using namespace std;
int a[10005];
int main()
{
bool t=1;
int n,j,i,k,m,x;
cin>>n>>k;
for(i=0;i<n;i++)
{
cin>>a[i];
}
for(i=0;i<n-1;i++)
{
for(j=0;j<n-1;j++)
{
if(a[j]<a[j+1])
{
swap(a[j],a[j+1]);
}
}
}
m=a[k-1]-a[n-k];
if(m==0||m==1)
{
t=0;
}
for(i=2;i*i<=m;i++)
{
if(m%i==0) {
t=0; break;
}
}
if(t==1)
{
cout<<"YES"<<endl<<m;
}
else {
cout<<"NO"<<endl<<m;
}
return 0;
}
/**************************************************************
Problem: 1242
User: 21A
Language: C++
Result: Accepted
Time:8 ms
Memory:2112 kb
****************************************************************/