Scenic Walkway più veloce

Buongiorno a tutti, con questo mio codice riesco ad ottenere 80/100, neqli ultimi 4 subtask sfora il limite di tempo. Un hint per renderlo più veloce?

#include <stdio.h>
#include <assert.h>
#include <algorithm>
#include <iterator>
#define MAXN 1000000
using namespace std;
int spread(int N, int K, int H[]) {
    
    int spreadmin;
    for(int i=0;i<N-(K-1);i++){
        int kmax=*max_element(H+i,H+i+K);
        int kmin=*min_element(H+i,H+i+K);
        int spread=kmax-kmin;
        if (i==0){
            spreadmin=spread;
        }
        else if(spread<spreadmin){
            spreadmin=spread;
        }
    }
    return spreadmin;
}

int H[MAXN];


int main() {
    FILE *fr, *fw;
    int N, K, i;
    fr = fopen("input.txt", "r");
    fw = fopen("output.txt", "w");
    assert(2 == fscanf(fr, "%d %d", &N, &K));
    for(i=0; i<N; i++)
        assert(1 == fscanf(fr, "%d", &H[i]));
    sort(H,H+N);
    fprintf(fw, "%d\n", spread(N, K, H));
    fclose(fr);
    fclose(fw);
    return 0;
}

Grazie mille