#include using namespace std; using ll=long long; using ld=long double; using vi=vector; using vl=vector; using pii=pair; using pll=pair; templateusing pqg=priority_queue,greater>; #define all(x) begin(x),end(x) #define rall(x) rbegin(x),rend(x) #define sz(x) (int)x.size() #define rep(i,a,b) for(int i=a;i=b;i--) const ll INF=4e18; const int MOD=1e9+7; const int MOD2=998244353; ll modpow(ll a,ll b,ll m=MOD){ ll r=1; while(b){ if(b&1)r=r*a%m; a=a*a%m; b>>=1; } return r; } struct DSU{ vi p,s; DSU(int n){p.resize(n);s.assign(n,1);iota(all(p),0);} int find(int x){return p[x]==x?x:p[x]=find(p[x]);} bool join(int a,int b){a=find(a);b=find(b);if(a==b)return 0;if(s[a]>g;vi lv,it; Dinic(int n):n(n),g(n),lv(n),it(n){} void add(int a,int b,ll c){ g[a].push_back({b,(int)g[b].size(),c}); g[b].push_back({a,(int)g[a].size()-1,0}); } bool bfs(int s,int t){ fill(all(lv),-1); queueq;q.push(s);lv[s]=0; while(q.size()){ int x=q.front();q.pop(); for(auto&e:g[x])if(e.cap&&lv[e.to]<0)lv[e.to]=lv[x]+1,q.push(e.to); } return lv[t]>=0; } ll dfs(int x,int t,ll f){ if(x==t)return f; for(int&i=it[x];i prefix(string s){ vectorp(sz(s)); rep(i,1,sz(s)){ int j=p[i-1]; while(j&&s[i]!=s[j])j=p[j-1]; if(s[i]==s[j])j++; p[i]=j; } return p; } vector zfunc(string s){ int n=sz(s),l=0,r=0; vectorz(n); rep(i,1,n){ if(i<=r)z[i]=min(r-i+1,z[i-l]); while(i+z[i]r)l=i,r=i+z[i]-1; } return z; } struct SAM{ struct Node{int nxt[26],link,len;Node(){memset(nxt,-1,sizeof(nxt));link=-1;len=0;}}; vectorst;int last; SAM(){st.push_back(Node());last=0;} void add(char c){ int cur=sz(st);st.push_back(Node());st[cur].len=st[last].len+1; int p=last; while(p!=-1&&st[p].nxt[c-'a']==-1){st[p].nxt[c-'a']=cur;p=st[p].link;} if(p==-1)st[cur].link=0; else st[cur].link=st[p].nxt[c-'a']; last=cur; } }; struct Point{ ld x,y; Point(){} Point(ld x,ld y):x(x),y(y){} Point operator-(Point p){return {x-p.x,y-p.y};} ld cross(Point p){return x*p.y-y*p.x;} }; pair dp[1005][1005]; void solve() { int n, m, l; cin >> n >> m >> l; vector a(n + 1), b(m + 1); for(int i=1;i<=n;i++) cin >> a[i]; for(int i=1;i<=m;i++) cin >> b[i]; sort(a.begin() + 1, a.end()); sort(b.begin() + 1, b.end()); ll low = -2e6, high = 2e6; ll ans = 0; while (low <= high) { ll mid = low + (high - low) / 2; for(int i=0;i<=n;i++) { for(int j=0;j<=m;j++) dp[i][j] = {0, 0}; } for (int i = 1; i <= n; i++) { for (int j = 1; j <= m; j++) { pair bst = dp[i-1][j]; if (dp[i][j-1].first < bst.first || (dp[i][j-1].first == bst.first && dp[i][j-1].second > bst.second)) { bst = dp[i][j-1]; } pair tk = dp[i-1][j-1]; tk.first += abs(a[i] - b[j]) - mid; tk.second += 1; if (tk.first < bst.first || (tk.first == bst.first && tk.second > bst.second)) { bst = tk; } dp[i][j] = bst; } } if (dp[n][m].second >= l) { ans = dp[n][m].first + mid * l; high = mid - 1; } else { low = mid + 1; } } cout << ans << "\n"; } int main() { ios::sync_with_stdio(false); cin.tie(nullptr); //int t = 1; // cin >> t; //while (t--) { solve(); //} return 0; }