#include<bits/stdc++.h>
using namespace std;
int L,N,K;
int s[105],m=0;
int slv(int x,int y,bool cr=1){
if(y==x) return x;
if(y==x+1&&cr) return y;
int mid=(x+y+1)/2,sum=0;
for(int i=0;i<N;i++)
sum+=s[i]/mid;
bool cc=(sum>K);
if(cr^cc) return slv(x,mid,cr);
else return slv(mid,y,cc);
}
int main(){
scanf("%d%d%d",&L,&N,&K);
scanf("%d",s);
N-=1;
for(int i=1,x;i<=N;i++){
scanf("%d",&x);
s[i-1]=x-s[i-1],s[i]=x;
m=max(m,s[i-1]);
}
cout<<slv(1,m);
return 0;
}