Cod sursa(job #1016961)

Utilizator Iustin_BulimarFMI Iustin Bulimar Iustin_Bulimar Data 26 octombrie 2013 23:32:27
Problema Statistici de ordine Scor 40
Compilator cpp Status done
Runda Arhiva educationala Marime 0.7 kb
#include <fstream>

using namespace std;

ifstream cin("sdo.in");
ofstream cout("sdo.out");

int stat(int v[], int st, int dr, int k)
{
      int i=st, j=dr;
      if(i==j) return v[i];
      int piv = v[(st+dr)/2];
      while (i <= j)
      {
            while (v[i] < piv) i++;
            while (v[j] > piv) j--;
            if (i <= j)
            {
                  swap(v[i],v[j]);
                  i++;
                  j--;
            }
      }
      if (k <= j) return stat(v, st, j, k);
      if (i <= k) return stat(v, i, dr, k);
}

int main()
{
    int n, v[500001], i, k;
    cin>>n>>k;
    for (i=1; i<=n; i++) cin>>v[i];
    cout<<stat(v, 1, n, k);
    return 0;
}