#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: ljl2
	Language: C++
	Result: Accepted
	Time:7 ms
	Memory:2112 kb
****************************************************************/